CSES - Datatähti 2015 loppu - Results
Submission details
Task:Pörssihai
Sender:PT
Submission time:2015-01-29 17:13:11 +0200
Language:C++
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.07 s1details
#20.05 s1details
#30.06 s1details
#40.07 s2details
#50.08 s2details
#60.07 s2details
#72.37 s3details
#82.44 s3details
#92.40 s3details
#102.39 s3details
#112.42 s3details
#122.34 s3details
#132.52 s3details
#142.51 s3details
#152.42 s3details
#163.22 s3details
#172.37 s3details
#182.44 s3details
#192.37 s3details
#202.47 s3details

Code

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define N 1000001

int n;
int a[N];
int p[N];
ll sum[N];
int e[N];

int main() {
  cin >> n;
  cin >> a[0];
  sum[0] = a[0];
  for(int i = 1; i < n; ++i) {
    cin >> a[i];
    sum[i] = sum[i - 1] + a[i];
  }
  for(int i = 0; i < n; ++i) {
    ll mBest = a[i];
    ll rBest = 1;
    int jBest = i;
    int j = i - 1;
    int bound = 0;
    while(j >= bound) {
      ll m = sum[i] - (j == 0 ? 0 : sum[j - 1]);
      ll r = (i - j + 1);
      if(m * rBest >= mBest * r) {
	mBest = m;
	rBest = r;
	jBest = j;
      }
      if(a[j] < m / (double)r) {
	bound = max(bound, e[j]);
      }
      if(a[j] >= (mBest / (double) rBest) && e[j] != j) {
	j = e[j];
      } else {
	--j;
      }
      --j;
    } 
    e[i] = jBest;
    cout << i - jBest + 1 << " ";
  }
  cout << "\n";
  return 0;
}

Test details

Test 1

Group: 1

Verdict:

input
200
5986 845897 759781 171305 7836...

correct output
1 1 2 3 4 1 1 2 4 1 2 1 2 5 6 ...

user output
1 1 2 2 4 1 1 2 4 1 2 1 2 4 4 ...

Test 2

Group: 1

Verdict:

input
200
607815 909742 130099 813674 34...

correct output
1 1 3 1 5 1 1 3 4 5 1 1 1 4 10...

user output
1 1 2 1 4 1 1 2 1 1 1 1 1 4 6 ...

Test 3

Group: 1

Verdict:

input
200
921591 381013 930275 151815 69...

correct output
1 2 1 4 5 1 2 3 4 1 2 7 1 2 3 ...

user output
1 2 1 4 2 1 2 1 4 1 2 6 1 2 2 ...

Test 4

Group: 2

Verdict:

input
5000
952303 272950 268680 897180 13...

correct output
1 2 3 1 2 1 4 8 9 10 1 2 13 14...

user output
1 2 2 1 2 1 4 1 6 8 1 2 10 4 1...

Test 5

Group: 2

Verdict:

input
5000
815856 460818 496023 308974 33...

correct output
1 2 3 4 5 1 1 2 9 1 11 12 13 1...

user output
1 2 1 4 4 1 1 2 4 1 6 6 1 1 1 ...

Test 6

Group: 2

Verdict:

input
5000
4889 373080 366119 72135 10214...

correct output
1 1 2 3 4 1 1 2 3 4 5 1 2 3 1 ...

user output
1 1 2 2 1 1 1 2 4 4 1 1 2 4 1 ...

Test 7

Group: 3

Verdict:

input
1000000
444890 370930 385763 316218 44...

correct output
1 2 3 4 1 2 3 4 9 1 2 1 4 5 6 ...

user output
1 2 1 4 1 2 4 8 8 1 2 1 4 4 4 ...

Test 8

Group: 3

Verdict:

input
1000000
202077 270536 246808 189471 19...

correct output
1 1 2 3 4 1 1 3 4 5 1 2 8 9 10...

user output
1 1 2 4 4 1 1 2 4 6 1 2 8 6 1 ...

Test 9

Group: 3

Verdict:

input
1000000
736301 784710 628727 708231 64...

correct output
1 1 3 4 5 6 7 1 2 1 4 1 1 7 1 ...

user output
1 1 2 1 4 1 6 1 2 1 4 1 1 6 1 ...

Test 10

Group: 3

Verdict:

input
1000000
242104 238293 242641 242281 24...

correct output
1 2 1 2 3 1 2 3 1 2 1 4 11 12 ...

user output
1 2 1 2 2 1 2 4 1 2 1 4 8 6 1 ...

Test 11

Group: 3

Verdict:

input
1000000
252952 189698 245317 275463 24...

correct output
1 2 1 1 2 4 7 1 2 3 1 2 3 1 1 ...

user output
1 2 1 1 2 4 4 1 2 1 1 2 4 1 1 ...

Test 12

Group: 3

Verdict:

input
1000000
214451 357457 213436 351167 21...

correct output
1 1 2 1 4 5 6 7 8 9 1 1 3 4 5 ...

user output
1 1 2 1 4 6 2 8 2 1 1 1 4 6 6 ...

Test 13

Group: 3

Verdict:

input
1000000
363703 361248 358992 356404 35...

correct output
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
1 2 2 4 2 6 2 8 2 10 2 12 2 14...

Test 14

Group: 3

Verdict:

input
1000000
718920 716974 715476 714540 71...

correct output
1 2 3 4 5 6 7 1 1 1 1 1 1 1 1 ...

user output
1 2 2 4 2 1 1 1 1 1 1 1 1 1 1 ...

Test 15

Group: 3

Verdict:

input
1000000
614078 647174 701983 580935 58...

correct output
1 1 1 3 4 1 6 8 9 1 1 3 4 14 1...

user output
1 1 1 2 1 1 4 1 6 1 1 2 1 6 1 ...

Test 16

Group: 3

Verdict:

input
1000000
788376 788632 788880 789118 78...

correct output
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...

user output
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...

Test 17

Group: 3

Verdict:

input
1000000
711774 711541 711305 711627 71...

correct output
1 2 3 1 2 6 1 2 1 2 3 6 7 1 2 ...

user output
1 2 2 1 2 6 1 2 1 2 4 4 6 1 2 ...

Test 18

Group: 3

Verdict:

input
1000000
685798 944128 587123 653271 65...

correct output
1 1 2 3 4 1 2 7 8 10 11 1 1 3 ...

user output
1 1 2 1 1 1 2 4 4 6 10 1 1 2 4...

Test 19

Group: 3

Verdict:

input
1000000
734074 734109 733868 733873 73...

correct output
1 1 3 4 5 1 1 1 1 1 1 1 3 5 6 ...

user output
1 1 2 1 1 1 1 1 1 1 1 1 4 6 8 ...

Test 20

Group: 3

Verdict:

input
1000000
143117 1 267468 262833 141471 ...

correct output
1 2 1 2 3 1 1 2 4 1 2 10 11 12...

user output
1 2 1 2 2 1 1 2 4 1 2 8 8 2 10...