CSES - Datatähti 2019 loppu - Results
Submission details
Task:Summa
Sender:Alexander Popov
Submission time:2019-01-17 16:29:40 +0200
Language:C++
Status:READY
Result:0
Feedback
groupverdictscore
#10
Test results
testverdicttime
#1ACCEPTED0.01 sdetails
#2ACCEPTED0.02 sdetails
#3ACCEPTED0.01 sdetails
#4ACCEPTED0.03 sdetails
#5ACCEPTED0.01 sdetails
#60.01 sdetails
#70.02 sdetails
#80.01 sdetails
#90.01 sdetails
#100.01 sdetails
#110.01 sdetails
#120.02 sdetails
#130.01 sdetails
#140.01 sdetails
#150.02 sdetails
#160.01 sdetails
#170.02 sdetails
#180.01 sdetails
#190.03 sdetails
#200.01 sdetails
#210.02 sdetails
#220.02 sdetails
#230.01 sdetails
#240.02 sdetails
#250.01 sdetails
#260.02 sdetails
#270.03 sdetails
#280.02 sdetails

Code

#include <cstdint>
#include <bits/stdc++.h>


// Rediscovering basic stuff
// YE BOI
int main() {
	std::string input;
	std::cin >> input;

	uint64_t count = 0;

	uint64_t bonus = 0;
//	std::vector<uint8_t> verticals;
	// Bonus is the count of EVEN verticals
	uint64_t zeroCount = 0;

	uint64_t verticalsSize = 0;
	uint64_t evenVerticals = 0; // oddVerticals = verticalsSize - evenVerticals;

	for (char c : input) {
		++verticalsSize;
		++evenVerticals;
		// verticals.push_back(1);
		if (c == '0') {
			++zeroCount;
			count += zeroCount + bonus; // bonus meme
		} else {
			zeroCount = 0;
			bonus = 0;
			// Haha, swap em
			evenVerticals = verticalsSize - evenVerticals;
			//for (unsigned i = 0; i < verticals.size(); ++i) {
			//	verticals[i] ^= 1;
			//	if (verticals[i] == 1) {
			//		bonus += 1;
			//	}
			//}
			bonus = evenVerticals;
			count += bonus;
		}
	}

	std::cout << count << std::endl;

	return 0;
}

Test details

Test 1

Verdict: ACCEPTED

input
1

correct output
0

user output
0

Test 2

Verdict: ACCEPTED

input
2

correct output
0

user output
0

Test 3

Verdict: ACCEPTED

input
3

correct output
0

user output
0

Test 4

Verdict: ACCEPTED

input
4

correct output
0

user output
0

Test 5

Verdict: ACCEPTED

input
5

correct output
0

user output
0

Test 6

Verdict:

input
6

correct output
1

user output
0

Test 7

Verdict:

input
7

correct output
1

user output
0

Test 8

Verdict:

input
8

correct output
2

user output
0

Test 9

Verdict:

input
9

correct output
3

user output
0

Test 10

Verdict:

input
10

correct output
4

user output
1

Test 11

Verdict:

input
20

correct output
24

user output
1

Test 12

Verdict:

input
30

correct output
61

user output
1

Test 13

Verdict:

input
40

correct output
114

user output
1

Test 14

Verdict:

input
50

correct output
184

user output
1

Test 15

Verdict:

input
60

correct output
271

user output
1

Test 16

Verdict:

input
70

correct output
374

user output
1

Test 17

Verdict:

input
80

correct output
494

user output
1

Test 18

Verdict:

input
90

correct output
631

user output
1

Test 19

Verdict:

input
100

correct output
784

user output
3

Test 20

Verdict:

input
200

correct output
3234

user output
3

Test 21

Verdict:

input
300

correct output
7351

user output
3

Test 22

Verdict:

input
400

correct output
13134

user output
3

Test 23

Verdict:

input
500

correct output
20584

user output
3

Test 24

Verdict:

input
600

correct output
29701

user output
3

Test 25

Verdict:

input
700

correct output
40484

user output
3

Test 26

Verdict:

input
800

correct output
52934

user output
3

Test 27

Verdict:

input
900

correct output
67051

user output
3

Test 28

Verdict:

input
1000

correct output
82834

user output
6