Submission details
Task:Array
Sender:Pietari Kaskela
Submission time:2015-09-30 18:16:50 +0300
Language:C++
Status:READY
Result:
Test results
testverdicttime
#10.05 sdetails
#20.05 sdetails
#30.06 sdetails
#40.05 sdetails
#50.05 sdetails
#60.06 sdetails
#70.06 sdetails
#80.08 sdetails
#90.09 sdetails
#100.07 sdetails
#110.07 sdetails
#120.14 sdetails
#130.09 sdetails
#140.08 sdetails
#150.10 sdetails
#160.08 sdetails
#170.08 sdetails
#180.09 sdetails
#190.10 sdetails
#20ACCEPTED0.10 sdetails
#210.06 sdetails

Code

#include <bits/stdc++.h>

#define i64 long long
#define u64 unsigned long long
#define i32 int
#define u32 unsigned int

#define pii pair<int, int>
#define pll pair<long long, long long>

#define defmod 1000000007
using namespace std;


int main(){
	cin.sync_with_stdio(0);
	cin.tie(0);
	
	int n, x; cin >> n >> x;
	i64 a[101010];
	for(int i = 0; i < n; i++)
		cin >> a[i];
	i64 s[101010] = {0};
	s[0] = a[0];
	unordered_map<i64, int> sums;
	i64 mi = 0;
	sums[a[0]] = 1;
	for(int i = 1; i < n; i++){
		s[i] = s[i-1]+a[i];
		sums[s[i]]++;
	}
	int re = sums[x];
	for(int i = 1; i < n; i++){
		mi-=a[i-1];
		re+=sums[x+mi];
	}
	cout << re << endl;


	return 0;
}

Test details

Test 1

Verdict:

input
89384 -6
-1 9 -2 0 0 -1 5 0 -8 9 10 -6 ...

correct output
2029635

user output
3426505

Test 2

Verdict:

input
32688 -4
6 0 9 -10 -2 -2 -1 5 -5 -6 9 8...

correct output
321307

user output
233821

Test 3

Verdict:

input
11023 2
5 0 -1 9 -10 3 10 -10 1 -3 -8 ...

correct output
146015

user output
25123

Test 4

Verdict:

input
36884 -7
6 8 2 -4 1 7 1 -7 5 3 1 -6 1 -...

correct output
471565

user output
331548

Test 5

Verdict:

input
2875 -6
-4 1 -6 -10 -2 -5 9 0 -2 9 -3 ...

correct output
9343

user output
13000

Test 6

Verdict:

input
52346 -111
973 629 570 312 541 -117 332 7...

correct output
8791

user output
8006

Test 7

Verdict:

input
55283 298
593 -881 937 901 -91 -622 632 ...

correct output
7351

user output
1177

Test 8

Verdict:

input
93592 -589
951 -193 -855 -692 926 -602 -6...

correct output
26431

user output
0

Test 9

Verdict:

input
98149 942
-816 178 196 -503 654 -474 -64...

correct output
37659

user output
32752

Test 10

Verdict:

input
79573 -346
-161 619 720 182 726 452 -63 -...

correct output
19690

user output
3014

Test 11

Verdict:

input
100000 -9229
-6207 -4894 -1224 8410 -2954 4...

correct output
1969

user output
162

Test 12

Verdict:

input
100000 4655
134 4684 8364 -7381 -1874 3429...

correct output
2353

user output
1856

Test 13

Verdict:

input
100000 -5901
-4907 7494 7673 -3917 -3223 -7...

correct output
2345

user output
1272

Test 14

Verdict:

input
100000 -2507
-845 -6674 -3174 9309 -1411 53...

correct output
2242

user output
20

Test 15

Verdict:

input
100000 -4850
-9232 -2843 5422 -5336 -2835 -...

correct output
3753

user output
62

Test 16

Verdict:

input
100000 -745023
-561148 78606 440682 608892 -3...

correct output
27

user output
20

Test 17

Verdict:

input
100000 987216
602043 416718 216813 720665 -6...

correct output
41

user output
36

Test 18

Verdict:

input
100000 -140762
-813926 -641015 5926 -87604 -8...

correct output
43

user output
6

Test 19

Verdict:

input
100000 -828680
-53023 -23367 -91278 162438 82...

correct output
27

user output
38

Test 20

Verdict: ACCEPTED

input
100000 -731243595
-728764339 -159138563 36776806...

correct output
0

user output
0

Test 21

Verdict:

input
100000 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...

correct output
5000050000

user output
1410065408