CSES - Leirikisa 9.12.2021 - Results
Submission details
Task:Pörssihai
Sender:Anniiiz
Submission time:2021-12-09 17:11:53 +0200
Language:C++ (C++11)
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED12
#2ACCEPTED17
#3ACCEPTED71
Test results
testverdicttimegroup
#1ACCEPTED0.01 s1details
#2ACCEPTED0.01 s1details
#3ACCEPTED0.01 s1details
#4ACCEPTED0.01 s2details
#5ACCEPTED0.01 s2details
#6ACCEPTED0.01 s2details
#7ACCEPTED0.77 s3details
#8ACCEPTED0.90 s3details
#9ACCEPTED0.92 s3details
#10ACCEPTED0.83 s3details
#11ACCEPTED0.77 s3details
#12ACCEPTED0.83 s3details
#13ACCEPTED0.90 s3details
#14ACCEPTED0.94 s3details
#15ACCEPTED0.79 s3details
#16ACCEPTED0.84 s3details
#17ACCEPTED0.85 s3details
#18ACCEPTED0.78 s3details
#19ACCEPTED0.96 s3details
#20ACCEPTED0.84 s3details

Code

#include <iostream>
#include <vector>
#include<algorithm>
#include <set>
#include <map>
using namespace std;
using ll = long long;
vector<ll> v;
double t[1000010][3];

int main() {
  ll n, a;
  cin >> n;
  for (int i = 0; i < n; ++i) {
    cin >> a;
    v.push_back(a);
  }
  t[0][0] = 1*1.0;
  t[0][1] = v[0];
  t[0][2] = v[0];
  for (int i = 1; i < n; ++i) {
    a = i-1;
    double s = v[i]*1.0;
    double l = 1;
    t[i][1] = s / l;
    t[i][0] = 1;
    t[i][2] = s;
    //cout << a << " " << s / l << " " << t[i][1] << " " << s << " " << l << endl;
    while (a >= 0 && t[a][2] / t[a][0] >= s / l) {
      //cout << i << " " << a << " " << s << " " << l << endl;
      s += t[a][2]* 1.0;
      l += t[a][0];
      //cout << "testi2 " << a << " " << t[a][0] << endl;
      a -= t[a][0];
      //cout << "testi " << a << " " << t[a][0] << endl;
      t[i][1] = s / l;
      t[i][0] = l;
      t[i][2] = s;
    }
  }
  for (int i = 0; i < n; ++i) {
    cout << t[i][0] << " ";
  }
  cout << endl;
}

Test details

Test 1

Group: 1

Verdict: ACCEPTED

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 3 4 1 1 2 4 1 2 1 2 5 6 ...
Truncated

Test 2

Group: 1

Verdict: ACCEPTED

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 3 1 5 1 1 3 4 5 1 1 1 4 10...
Truncated

Test 3

Group: 1

Verdict: ACCEPTED

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 5 1 2 3 4 1 2 7 1 2 3 ...
Truncated

Test 4

Group: 2

Verdict: ACCEPTED

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 3 1 2 1 4 8 9 10 1 2 13 14...
Truncated

Test 5

Group: 2

Verdict: ACCEPTED

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 3 4 5 1 1 2 9 1 11 12 13 1...
Truncated

Test 6

Group: 2

Verdict: ACCEPTED

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 3 4 1 1 2 3 4 5 1 2 3 1 ...
Truncated

Test 7

Group: 3

Verdict: ACCEPTED

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 3 4 1 2 3 4 9 1 2 1 4 5 6 ...
Truncated

Test 8

Group: 3

Verdict: ACCEPTED

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 3 4 1 1 3 4 5 1 2 8 9 10...
Truncated

Test 9

Group: 3

Verdict: ACCEPTED

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 3 4 5 6 7 1 2 1 4 1 1 7 1 ...
Truncated

Test 10

Group: 3

Verdict: ACCEPTED

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 3 1 2 3 1 2 1 4 11 12 ...
Truncated

Test 11

Group: 3

Verdict: ACCEPTED

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 7 1 2 3 1 2 3 1 1 ...
Truncated

Test 12

Group: 3

Verdict: ACCEPTED

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 5 6 7 8 9 1 1 3 4 5 ...
Truncated

Test 13

Group: 3

Verdict: ACCEPTED

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 3 4 5 6 7 8 9 10 11 12 13 ...
Truncated

Test 14

Group: 3

Verdict: ACCEPTED

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 3 4 5 6 7 1 1 1 1 1 1 1 1 ...
Truncated

Test 15

Group: 3

Verdict: ACCEPTED

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 3 4 1 6 8 9 1 1 3 4 14 1...
Truncated

Test 16

Group: 3

Verdict: ACCEPTED

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 ...
Truncated

Test 17

Group: 3

Verdict: ACCEPTED

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 3 1 2 6 1 2 1 2 3 6 7 1 2 ...
Truncated

Test 18

Group: 3

Verdict: ACCEPTED

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 3 4 1 2 7 8 10 11 1 1 3 ...
Truncated

Test 19

Group: 3

Verdict: ACCEPTED

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 3 4 5 1 1 1 1 1 1 1 3 5 6 ...
Truncated

Test 20

Group: 3

Verdict: ACCEPTED

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 3 1 1 2 4 1 2 10 11 12...
Truncated