-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbinary_string.py
More file actions
59 lines (56 loc) · 1.27 KB
/
binary_string.py
File metadata and controls
59 lines (56 loc) · 1.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
def list_to_number(lis):
sum = 0
n = len(lis)
for i in range(n):
sum += lis[i] * 2**(n-i-1)
return sum
numbers = set()
def subsets(n, index, output, li):
global numbers
if index == n:
if len(output) == 0:
return
else:
#print(output)
a = list_to_number(output)
#print(a)
numbers.add(a)
return
subsets(n, index+1, output, li)
output.append(li[index])
subsets(n, index+1, output, li)
output.pop()
for test_case in range(int(input())):
numbers = set()
binary_input = int(input())
res = [int(x) for x in str(binary_input)]
subsets(len(res), 0, [], res)
num = list(numbers)
num.sort()
print(num)
#found = False
#if num[0] != 0:
# print(0)
# continue
#for i in range(len(num) - 1):
# if num[i+1] - num[i] != 1:
# a = num[i] + 1
# found = True
# break
#if not found:
# a = num[len(num) - 1] + 1
#a = str(bin(a))
#for i in range(2, len(a)):
# print(a[i], end='')
#print('')
#10#
#110101
#111101010
#1010101010101110
#11101010101011010
#1010101101011101011
#1111010101010101110
#1101010101011110101
#11110010101010101
#111101000000111010
#100000000000