Thử thách của bạn là lấy đầu vào như thế này (một chương trình Hello World):
++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>->>+[<]<-]>>.>---.+++++++..+++.>>.<-.<.+++.------.--------.>>+.>++.
Và xuất ra một dấu nhắc (sẽ là "> "
):
>
Người dùng sau đó có thể nhập bất cứ điều gì tại dấu nhắc. Trình gỡ lỗi đơn giản của bạn phải có các lệnh sau:
S
- bươc- Xuất vị trí hiện tại (xem
L
) sau khi bước. S(a positive integer)
- bước nhiều không gian
- Xuất vị trí hiện tại (xem
L
- vị trí- Thuật ngữ "vị trí" luôn đề cập đến vị trí của bạn trong chương trình (nghĩa là con trỏ lệnh).
Định dạng như thế này:
v +++++++[>+++++++<-]>.
Điều này có nghĩa là vị trí hiện tại của chương trình là ở vị trí thứ ba
+
.
G(an integer)
- đi đến- Điều này có nghĩa là tiếp tục bước cho đến khi bạn đến vị trí đó. Nếu bạn đến cuối chương trình và bạn chưa đến đó, chỉ cần thoát khỏi chương trình.
- Một số nguyên âm có nghĩa là nhiều ký tự từ cuối. Vâng, điều này có nghĩa
-0
là khác với0
, và-1
là nhân vật thứ hai cuối cùng. - Đừng xuất bất cứ thứ gì cho lệnh này.
D
- đổ mảng- Định dạng như
1, 2, 3, 4, 5
- Nếu mảng là
1, 2, 3, 0, 0, 0, 0, 0, ...
, chỉ đầu ra1, 2, 3
. D(a positive integer) (a positive integer)
- kết xuất tất cả các mục mảng giữa hai vị trí đó (bao gồm)
- Định dạng như
(a positive integer)
- xuất mục hiện tại vị trí mảng đóP
- xuất chỉ mục của con trỏ BF (thứ bạn thay đổi>
và<
).
Khi chương trình yêu cầu đầu vào, hiển thị lời nhắc "I> "
. (Bạn có thể nhập một ký tự một lần.)
Khi nó xuất ra một cái gì đó, hiển thị "O> " + (the output)
. Nhiều đầu ra giữa các lệnh phải được nối lại với nhau (nghĩa là bạn không thể làm được > G-0 O> H O> e O> l O> l O> o ...
, nó phải như vậy > G-0 O> Hello, World!
).
Xuất "Xong" và thoát khi bạn kết thúc chương trình.
Chạy mẫu:
++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>->>+[<]<-]>>.>---.+++++++..+++.>>.<-.<.+++.------.--------.>>+.>++.
> S
1
> S
2
> S2
4
> S0
4
> L
v
++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>->>+[<]<-]>>.>---.+++++++..+++.>>.<-.<.+++.------.--------.>>+.>++.
> D
4
> 0
4
> D10 15
0, 0, 0, 0, 0, 0
> G-0
O> Hello, World!
Done
Chạy mẫu cho thấy bước qua các vòng và P
hướng dẫn (tính toán 3*2+1
)
+++[>++<-]>+
> S3
3
> L
v
+++[>++<-]>+
> S3
6
> L
v
+++[>++<-]>+
> P
1
> S3
9
> L
v
+++[>++<-]>+
> S
3
> L
v
+++[>++<-]>+
> D
2, 2
>
Chạy mẫu hiển thị I / O
>+[>,---------------------------------]<[<]>[>.]
> G37
I> H
I> e
I> l
I> l
I> o
I> !
> D
0, 39, 68, 75, 75, 78
> G-0
O> 'DKKN
Done
Đây là mã golf , vì vậy mã ngắn nhất sẽ giành chiến thắng.