Task: | Bittijono |
Sender: | Olli |
Submission time: | 2017-10-08 10:32:30 +0300 |
Language: | C++ |
Status: | READY |
Result: | 42 |
group | verdict | score |
---|---|---|
#1 | WRONG ANSWER | 0 |
#2 | ACCEPTED | 15 |
#3 | ACCEPTED | 27 |
#4 | TIME LIMIT EXCEEDED | 0 |
test | verdict | time | group | |
---|---|---|---|---|
#1 | WRONG ANSWER | 0.06 s | 1 | details |
#2 | WRONG ANSWER | 0.04 s | 1 | details |
#3 | WRONG ANSWER | 0.06 s | 1 | details |
#4 | WRONG ANSWER | 0.07 s | 1 | details |
#5 | WRONG ANSWER | 0.04 s | 1 | details |
#6 | WRONG ANSWER | 0.04 s | 1 | details |
#7 | WRONG ANSWER | 0.06 s | 1 | details |
#8 | WRONG ANSWER | 0.04 s | 1 | details |
#9 | WRONG ANSWER | 0.07 s | 1 | details |
#10 | WRONG ANSWER | 0.07 s | 1 | details |
#11 | ACCEPTED | 0.04 s | 2 | details |
#12 | ACCEPTED | 0.05 s | 2 | details |
#13 | ACCEPTED | 0.05 s | 2 | details |
#14 | ACCEPTED | 0.04 s | 2 | details |
#15 | ACCEPTED | 0.05 s | 2 | details |
#16 | ACCEPTED | 0.04 s | 2 | details |
#17 | ACCEPTED | 0.04 s | 2 | details |
#18 | ACCEPTED | 0.05 s | 2 | details |
#19 | ACCEPTED | 0.06 s | 2 | details |
#20 | ACCEPTED | 0.07 s | 2 | details |
#21 | ACCEPTED | 0.07 s | 3 | details |
#22 | ACCEPTED | 0.06 s | 3 | details |
#23 | ACCEPTED | 0.08 s | 3 | details |
#24 | ACCEPTED | 0.06 s | 3 | details |
#25 | ACCEPTED | 0.06 s | 3 | details |
#26 | ACCEPTED | 0.06 s | 3 | details |
#27 | ACCEPTED | 0.07 s | 3 | details |
#28 | ACCEPTED | 0.07 s | 3 | details |
#29 | ACCEPTED | 0.07 s | 3 | details |
#30 | ACCEPTED | 0.08 s | 3 | details |
#31 | TIME LIMIT EXCEEDED | -- | 4 | details |
#32 | TIME LIMIT EXCEEDED | -- | 4 | details |
#33 | TIME LIMIT EXCEEDED | -- | 4 | details |
#34 | TIME LIMIT EXCEEDED | -- | 4 | details |
#35 | TIME LIMIT EXCEEDED | -- | 4 | details |
#36 | TIME LIMIT EXCEEDED | -- | 4 | details |
#37 | TIME LIMIT EXCEEDED | -- | 4 | details |
#38 | TIME LIMIT EXCEEDED | -- | 4 | details |
#39 | TIME LIMIT EXCEEDED | -- | 4 | details |
#40 | TIME LIMIT EXCEEDED | -- | 4 | details |
Code
#include <iostream> using namespace std; //this seems to be too slow for 100 points, even though it seems to be O(n log n), assuming that the answer to the problem is O(n). This assumption seems to be wrong. QAQ. int stringInBinary[30]; int length; int subsSoFar[30]; int subsEndHere[30]; int uniqueSubsEndHere[30]; void increase() { stringInBinary[1]++; int i = 1; while(stringInBinary[i] == 2) { stringInBinary[i] = 0; stringInBinary[i+1]++; i++; } if(stringInBinary[length+1]) { length++; } } int amountOfSubstrings() { for(int i = 1; i <= 29; i++) { subsSoFar[i] = 0; uniqueSubsEndHere[i] = 0; subsEndHere[i] = 0; } subsSoFar[0] = 1; uniqueSubsEndHere[0] = 1; subsEndHere[0] = 1; int lastIndexEndingWithOne = 29; int lastIndexEndingWithZero = 29; for(int i = 1; i <= length; i++) { int bit = stringInBinary[i]; if(bit == 0) { subsEndHere[i] = subsSoFar[i-1]; uniqueSubsEndHere[i] = subsSoFar[i-1] - subsEndHere[lastIndexEndingWithZero]; subsSoFar[i] = subsSoFar[i-1] + uniqueSubsEndHere[i]; lastIndexEndingWithZero = i; } else { subsEndHere[i] = subsSoFar[i-1]; uniqueSubsEndHere[i] = subsSoFar[i-1] - subsEndHere[lastIndexEndingWithOne]; subsSoFar[i] = subsSoFar[i-1] + uniqueSubsEndHere[i]; lastIndexEndingWithOne = i; } } return subsSoFar[length] - 1; } int main() { int n; cin >> n; if(n <= 10) { cout << "Such n does not exist!" << "\n"; return 0; } stringInBinary[1] = 1; length = 1; while(amountOfSubstrings() != n) { increase(); } for(int i = length; i >= 1; i--) { cout << stringInBinary[i]; } }
Test details
Test 1
Group: 1
Verdict: WRONG ANSWER
input |
---|
1 |
correct output |
---|
1 |
user output |
---|
Such n does not exist! |
Test 2
Group: 1
Verdict: WRONG ANSWER
input |
---|
2 |
correct output |
---|
11 |
user output |
---|
Such n does not exist! |
Test 3
Group: 1
Verdict: WRONG ANSWER
input |
---|
3 |
correct output |
---|
10 |
user output |
---|
Such n does not exist! |
Test 4
Group: 1
Verdict: WRONG ANSWER
input |
---|
4 |
correct output |
---|
1111 |
user output |
---|
Such n does not exist! |
Test 5
Group: 1
Verdict: WRONG ANSWER
input |
---|
5 |
correct output |
---|
110 |
user output |
---|
Such n does not exist! |
Test 6
Group: 1
Verdict: WRONG ANSWER
input |
---|
6 |
correct output |
---|
101 |
user output |
---|
Such n does not exist! |
Test 7
Group: 1
Verdict: WRONG ANSWER
input |
---|
7 |
correct output |
---|
1110 |
user output |
---|
Such n does not exist! |
Test 8
Group: 1
Verdict: WRONG ANSWER
input |
---|
8 |
correct output |
---|
1100 |
user output |
---|
Such n does not exist! |
Test 9
Group: 1
Verdict: WRONG ANSWER
input |
---|
9 |
correct output |
---|
1101 |
user output |
---|
Such n does not exist! |
Test 10
Group: 1
Verdict: WRONG ANSWER
input |
---|
10 |
correct output |
---|
1001 |
user output |
---|
Such n does not exist! |
Test 11
Group: 2
Verdict: ACCEPTED
input |
---|
38 |
correct output |
---|
1101011 |
user output |
---|
1101011 |
Test 12
Group: 2
Verdict: ACCEPTED
input |
---|
13 |
correct output |
---|
11011 |
user output |
---|
11011 |
Test 13
Group: 2
Verdict: ACCEPTED
input |
---|
90 |
correct output |
---|
111001010 |
user output |
---|
100100010 |
Test 14
Group: 2
Verdict: ACCEPTED
input |
---|
25 |
correct output |
---|
110010 |
user output |
---|
101100 |
Test 15
Group: 2
Verdict: ACCEPTED
input |
---|
82 |
correct output |
---|
111001101 |
user output |
---|
100010011 |
Test 16
Group: 2
Verdict: ACCEPTED
input |
---|
94 |
correct output |
---|
1100011110 |
user output |
---|
1000011100 |
Test 17
Group: 2
Verdict: ACCEPTED
input |
---|
100 |
correct output |
---|
1111001001 |
user output |
---|
1001001111 |
Test 18
Group: 2
Verdict: ACCEPTED
input |
---|
99 |
correct output |
---|
110010010 |
user output |
---|
100011010 |
Test 19
Group: 2
Verdict: ACCEPTED
input |
---|
98 |
correct output |
---|
110110010 |
user output |
---|
100111010 |
Test 20
Group: 2
Verdict: ACCEPTED
input |
---|
92 |
correct output |
---|
100110001 |
user output |
---|
100011001 |
Test 21
Group: 3
Verdict: ACCEPTED
input |
---|
1666 |
correct output |
---|
101101100100101 |
user output |
---|
100100010101010 |
Test 22
Group: 3
Verdict: ACCEPTED
input |
---|
897 |
correct output |
---|
11101001101010 |
user output |
---|
10100010110100 |
Test 23
Group: 3
Verdict: ACCEPTED
input |
---|
4466 |
correct output |
---|
111101010110100101 |
user output |
---|
101001001110001011 |
Test 24
Group: 3
Verdict: ACCEPTED
input |
---|
4240 |
correct output |
---|
11011001011010101 |
user output |
---|
10101011010011011 |
Test 25
Group: 3
Verdict: ACCEPTED
input |
---|
3089 |
correct output |
---|
1011001010100101 |
user output |
---|
1010010101001101 |
Test 26
Group: 3
Verdict: ACCEPTED
input |
---|
4697 |
correct output |
---|
11010101101010110 |
user output |
---|
10010101001010100 |
Test 27
Group: 3
Verdict: ACCEPTED
input |
---|
4608 |
correct output |
---|
11010110101001010 |
user output |
---|
10101101010010100 |
Test 28
Group: 3
Verdict: ACCEPTED
input |
---|
4625 |
correct output |
---|
111011001100101001 |
user output |
---|
100010101110110110 |
Test 29
Group: 3
Verdict: ACCEPTED
input |
---|
4611 |
correct output |
---|
11010101010101100 |
user output |
---|
10101101011010100 |
Test 30
Group: 3
Verdict: ACCEPTED
input |
---|
4917 |
correct output |
---|
10110100101010110 |
user output |
---|
10010101011010010 |
Test 31
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
178555 |
correct output |
---|
1011010110110101010110110 |
user output |
---|
(empty) |
Test 32
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
864856 |
correct output |
---|
10111010110110100100101010010 |
user output |
---|
(empty) |
Test 33
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
112146 |
correct output |
---|
1101110101011001100100110 |
user output |
---|
(empty) |
Test 34
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
741124 |
correct output |
---|
1011010011010101100101011010 |
user output |
---|
(empty) |
Test 35
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
511902 |
correct output |
---|
1011010100011010100101001110 |
user output |
---|
(empty) |
Test 36
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
920019 |
correct output |
---|
11100100101101010101001101010 |
user output |
---|
(empty) |
Test 37
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
933943 |
correct output |
---|
10101011010100100110100111001 |
user output |
---|
(empty) |
Test 38
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
973410 |
correct output |
---|
1011010101011010101010101001 |
user output |
---|
(empty) |
Test 39
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
954943 |
correct output |
---|
10110110010011010100100110101 |
user output |
---|
(empty) |
Test 40
Group: 4
Verdict: TIME LIMIT EXCEEDED
input |
---|
911674 |
correct output |
---|
1010110010110101010101010110 |
user output |
---|
(empty) |