CSES - Datatähti 2015 loppu - Results
Submission details
Task:Pörssihai
Sender:eXeP
Submission time:2015-01-29 14:50:34 +0200
Language:C++
Status:READY
Result:29
Feedback
groupverdictscore
#1ACCEPTED12
#2ACCEPTED17
#30
Test results
testverdicttimegroup
#1ACCEPTED0.06 s1details
#2ACCEPTED0.06 s1details
#3ACCEPTED0.06 s1details
#4ACCEPTED0.77 s2details
#5ACCEPTED0.85 s2details
#6ACCEPTED0.79 s2details
#7--3details
#8--3details
#9--3details
#10--3details
#11--3details
#12--3details
#13--3details
#14--3details
#15--3details
#16--3details
#17--3details
#18--3details
#19--3details
#20--3details

Compiler report

input/code.cpp: In function 'int main(int, char**)':
input/code.cpp:30:15: warning: unused variable 'cmax' [-Wunused-variable]
     long long cmax = a[0];
               ^
input/code.cpp:31:12: warning: unused variable 'pmax' [-Wunused-variable]
     double pmax = 0;
            ^
input/code.cpp:32:9: warning: unused variable 'suur' [-Wunused-variable]
     int suur = 0;
         ^

Code

/* 
 * File:   main.cpp
 * Author: piekask
 *
 * Created on 29. tammikuuta 2015, 13:50
 */

#include <bits/stdc++.h>

using namespace std;

/*
 * 
 */

int main(int argc, char** argv) {
    cin.sync_with_stdio(0);
    cin.tie(0);
    double e = 0.0000001;
    int n; cin >> n;
    
    vector<long long> a(n);
    for(int i = 0; i < n; i++)
        cin >> a[i];
    vector<long long> s(n, 0);
    s[0] = a[0];
    for(int i = 1; i < n; i++)
        s[i] = s[i-1]+a[i];
    
    long long cmax = a[0];
    double pmax = 0;
    int suur = 0;
    vector<pair<double, int> > dp(n, {0, 0});
    dp[0] = {a[0], 1};
    for(int i = 1; i < n; i++){
        dp[i] = {a[i], 1};
        for(int j = 0; j < i; j++){
            
            long long ll = s[i]-(j>0?s[j-1]:0);
            double d = i-j+1;
            //cout << "summa " << j << "-" << i << " on " << ll << " ja d " << d <<endl;
            if(abs(ll/d-dp[i].first)<e){
                dp[i].second = d;
            }
            else if(ll/d>dp[i].first)
                dp[i] = {ll/d, d};
        }
        //cout << i<<" suurin " << dp[i].first << " ja d " << dp[i].second << endl;
     }
    for(int i = 0; i < n; i++)
        cout << dp[i].second << " ";
    cout << endl;
    return 0;
}

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

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

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

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

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

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

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)

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
(empty)