Bạn sẽ được cung cấp một chuỗi s
. Nó được đảm bảo rằng chuỗi có bằng nhau và ít nhất một [
s và ]
s. Nó cũng được đảm bảo rằng các dấu ngoặc được cân bằng. Chuỗi cũng có thể có các ký tự khác.
Mục tiêu là xuất / trả về một danh sách các bộ dữ liệu hoặc một danh sách các danh sách chứa các chỉ số của từng [
và ]
cặp.
lưu ý: Chuỗi không có chỉ mục.
Ví dụ:
!^45sdfd[hello world[[djfut]%%357]sr[jf]s][srtdg][]
nên trả lại
[(8, 41), (20, 33), (21, 27), (36, 39), (42, 48), (49, 50)]
hoặc một cái gì đó tương đương với điều này. Tuples là không cần thiết. Danh sách cũng có thể được sử dụng.
Các trường hợp thử nghiệm:
input:[[asdf][][td([)ty54g% ]hg[[f]u][f[[jhg][gfd]sdf]sdfs]ghd]fr43f]
output:[(0, 62),(1, 6), (7, 8), (9, 56), (13, 22), (25, 30), (26, 28), (31, 52), (33, 47), (34, 38), (39, 43)]
input:[[][][][]][[][][][[[[(]]]]]))
output:[(0, 9), (1, 2), (3, 4), (5, 6), (7, 8), (10,26),(11, 12), (13, 14), (15, 16), (17, 25), (18, 24), (19, 23), (20, 22)]
input:[][][[]]
output:[(0, 1), (2, 3), (4, 7), (5, 6)]
input:[[[[[asd]as]sd]df]fgf][][]
output:[(0, 21), (1, 17), (2, 14), (3, 11), (4, 8), (22, 23), (24, 25)]
input:[]
output:[(0,1)]
input:[[(])]
output:[(0, 5), (1, 3)]
Đây là mã golf , vì vậy mã ngắn nhất tính theo byte cho mỗi ngôn ngữ lập trình sẽ thắng.