Submission #382794

# Submission time Handle Problem Language Result Execution time Memory
382794 2021-03-28T08:20:36 Z kshitij_sodani Aliens (IOI16_aliens) C++14
100 / 100
1500 ms 17212 KB
//#pragma GCC optimize("Ofast,unroll-loops")
#include <bits/stdc++.h>
using namespace std;
typedef long long llo;
#define mp make_pair
#define pb push_back
#define a first 
#define b second
#define xx int
//#define endl '\n'
 
 
 
#include "aliens.h"
int mi[1000001];
llo dp[100001];
llo cnt[100001];
pair<llo,llo> sect(pair<llo,llo> aa,pair<llo,llo> bb){
   pair<llo,llo> cc={bb.b-aa.b,aa.a-bb.a};
   if(cc.b<0){
      cc.b=-cc.b;
      cc.a=-cc.a;
   }
   return cc;
}
llo eval(pair<llo,llo> aa,llo bb){
   return aa.a*bb+aa.b;
}
vector<pair<llo,llo>> ss;
llo kk;
pair<llo,llo> check(llo mid){
   vector<pair<llo,llo>> ee;
      llo ind=0;
      map<llo,llo> xz;
      for(llo j=0;j<ss.size();j++){
         dp[j]=(ss[j].b-ss[0].a+1);
         dp[j]*=dp[j];
         cnt[j]=1;
         /*if(i==1){
            continue;
         }*/
         if(ee.size()){
            while(ind+1<ee.size()){
               if(eval(ee[ind],ss[j].b)>=eval(ee[ind+1],ss[j].b)){
                  ind++;
               }
               else{
                  break;
               }
            }
            llo ac=eval(ee[ind],ss[j].b)+ss[j].b*ss[j].b;
            if(ac<dp[j]){
               dp[j]=ac;
               cnt[j]=1+cnt[xz[ee[ind].a]];
            }
         }
        /* if(mid==1023 and j==2){
            cout<<ind<<",,"<<endl;
            for(auto j:ee){
               cout<<j.a<<"::"<<j.b<<endl;
            }
         }*/
         dp[j]+=mid;
         if(j+1<ss.size()){
            llo a2=max(ss[j].b+1-ss[j+1].a,(llo)0);
            a2*=a2;
            a2=-a2;
            a2+=(ss[j+1].a-1)*(ss[j+1].a-1);
            a2+=dp[j];
            llo mm=-2*(ss[j+1].a-1);
            pair<llo,llo> ne={mm,a2};
            while(ee.size()>=2){
               pair<llo,llo> ac=sect(ee.back(),ee[ee.size()-2]);
               pair<llo,llo> bc=sect(ee[ee.size()-2],ne);
               //bc<ac
               if(bc.a*ac.b<bc.b*ac.a){
                  ee.pop_back();
               }
               else{
                  break;
               }
            }
            ee.pb({mm,a2});
            xz[ne.a]=j;
         }
      }
    /*  cout<<mid<<"::";
      for(int i=0;i<ss.size();i++){
         cout<<dp[i]<<",";
      }
      cout<<endl;*/
      return {cnt[ss.size()-1],dp[ss.size()-1]-mid*kk};
}
long long take_photos(xx n, xx m, xx k,vector<xx> aa,vector<xx> bb) {
     ss.clear();
    for(llo i=0;i<m;i++){
      mi[i]=-1;
    }
    for(llo i=0;i<n;i++){
      mi[min(aa[i],bb[i])]=max(mi[min(aa[i],bb[i])],max(aa[i],bb[i]));
      
      }
      llo cur=-1;
      for(llo i=0;i<m;i++){
         if(mi[i]!=-1){
            if(mi[i]>cur){
               ss.pb({i,mi[i]});
               cur=mi[i];
            }
         }
      }
/*      for(auto j:ss){
         cout<<j.a<<"::"<<j.b<<endl;
      }*/
      k=min(k,(int)ss.size());
      kk=k;
      /*for(int i=0;i<ss.size();i++){
         for(int j=1;j<=k+1;j++){
            dp[i].pb(0);
         }
      }*/
      llo low=0;
      for(llo i=39;i>=0;i--){
            if(i>0){
               if((1LL<<(i-1))>(llo)m*(llo)m){
                  continue;
               }
            }
         //if(low-(1LL<<i)>=0){
            if(check(low+(1LL<<i)).a>=k){
               low+=(1LL<<i);
            }
         //}
      }
     // assert(check(low).a==k);
 
     // cout<<low<<"::"<<endl;
     // cout<<check(low).a<<":"<<check(low).b<<endl;
 
      //cout<<check(low).a<<"::"<<endl;
 
      return check(low).b;
   /* for(llo i=1;i<=k;i++){
         vector<pair<llo,llo>> ee;
         llo ind=0;
         for(llo j=0;j<ss.size();j++){
            dp[j][i]=(ss[j].b-ss[0].a+1);
            dp[j][i]*=dp[j][i];
            if(i==1){
               continue;
            }
            if(ee.size()){
               while(ind+1<ee.size()){
                  if(eval(ee[ind],ss[j].b)>=eval(ee[ind+1],ss[j].b)){
                     ind++;
                  }
                  else{
                     break;
                  }
               }
               dp[j][i]=min(dp[j][i],eval(ee[ind],ss[j].b)+ss[j].b*ss[j].b);
            }
            if(j+1<ss.size()){
               llo a2=max(ss[j].b+1-ss[j+1].a,(llo)0);
               a2*=a2;
               a2=-a2;
               a2+=(ss[j+1].a-1)*(ss[j+1].a-1);
               a2+=dp[j][i-1];
               llo mm=-2*(ss[j+1].a-1);
               pair<llo,llo> ne={mm,a2};
               while(ee.size()>=2){
                  pair<llo,llo> ac=sect(ee.back(),ee[ee.size()-2]);
                  pair<llo,llo> bc=sect(ee[ee.size()-2],ne);
                  //bc<ac
                  if(bc.a*ac.b<bc.b*ac.a){
                     ee.pop_back();
                  }
                  else{
                     break;
                  }
               }
               ee.pb({mm,a2});
            }
         }
      }*/
  /*  for(llo i=1;i<=k;i++){
         for(llo j=0;j<ss.size();j++){
            cout<<dp[j][i]<<",";
         }
         cout<<endl;
      }*/
      /*cout<<dp[0][1]<<"::"<<dp[1][1]<<endl;
      for(auto j:ss){
         cout<<j.a<<":"<<j.b<<endl;
      }
      cout<<endl;
*/
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  //  return dp[ss.size()-1][k];
}

Compilation message

aliens.cpp: In function 'std::pair<long long int, long long int> check(llo)':
aliens.cpp:35:20: warning: comparison of integer expressions of different signedness: 'llo' {aka 'long long int'} and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   35 |       for(llo j=0;j<ss.size();j++){
      |                   ~^~~~~~~~~~
aliens.cpp:43:24: warning: comparison of integer expressions of different signedness: 'llo' {aka 'long long int'} and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   43 |             while(ind+1<ee.size()){
      |                   ~~~~~^~~~~~~~~~
aliens.cpp:64:16: warning: comparison of integer expressions of different signedness: 'llo' {aka 'long long int'} and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   64 |          if(j+1<ss.size()){
      |             ~~~^~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Correct answer: answer = 4
2 Correct 1 ms 364 KB Correct answer: answer = 4
3 Correct 1 ms 364 KB Correct answer: answer = 4
4 Correct 1 ms 364 KB Correct answer: answer = 12
5 Correct 1 ms 364 KB Correct answer: answer = 52
6 Correct 1 ms 364 KB Correct answer: answer = 210
7 Correct 1 ms 364 KB Correct answer: answer = 88
8 Correct 1 ms 364 KB Correct answer: answer = 7696
9 Correct 1 ms 364 KB Correct answer: answer = 1
10 Correct 1 ms 364 KB Correct answer: answer = 2374
11 Correct 1 ms 364 KB Correct answer: answer = 9502
12 Correct 1 ms 364 KB Correct answer: answer = 49
13 Correct 1 ms 364 KB Correct answer: answer = 151
14 Correct 1 ms 364 KB Correct answer: answer = 7550
15 Correct 1 ms 364 KB Correct answer: answer = 7220
16 Correct 1 ms 364 KB Correct answer: answer = 7550
17 Correct 1 ms 364 KB Correct answer: answer = 10000
18 Correct 1 ms 364 KB Correct answer: answer = 10000
19 Correct 1 ms 364 KB Correct answer: answer = 624
20 Correct 1 ms 320 KB Correct answer: answer = 10000
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Correct answer: answer = 1
2 Correct 1 ms 364 KB Correct answer: answer = 4
3 Correct 1 ms 364 KB Correct answer: answer = 1
4 Correct 1 ms 364 KB Correct answer: answer = 5
5 Correct 1 ms 364 KB Correct answer: answer = 41
6 Correct 1 ms 364 KB Correct answer: answer = 71923
7 Correct 2 ms 364 KB Correct answer: answer = 77137
8 Correct 2 ms 384 KB Correct answer: answer = 764
9 Correct 2 ms 364 KB Correct answer: answer = 250000
10 Correct 3 ms 364 KB Correct answer: answer = 500
11 Correct 1 ms 364 KB Correct answer: answer = 32
12 Correct 2 ms 364 KB Correct answer: answer = 130050
13 Correct 3 ms 364 KB Correct answer: answer = 5110
14 Correct 2 ms 364 KB Correct answer: answer = 2626
15 Correct 2 ms 364 KB Correct answer: answer = 796
16 Correct 3 ms 364 KB Correct answer: answer = 7580
17 Correct 3 ms 364 KB Correct answer: answer = 1904
18 Correct 2 ms 364 KB Correct answer: answer = 996004
19 Correct 2 ms 364 KB Correct answer: answer = 38817
20 Correct 2 ms 364 KB Correct answer: answer = 4096
21 Correct 1 ms 364 KB Correct answer: answer = 1
22 Correct 1 ms 364 KB Correct answer: answer = 1
23 Correct 3 ms 364 KB Correct answer: answer = 2040
24 Correct 1 ms 364 KB Correct answer: answer = 2
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Correct answer: answer = 4
2 Correct 1 ms 364 KB Correct answer: answer = 4
3 Correct 1 ms 364 KB Correct answer: answer = 4
4 Correct 1 ms 364 KB Correct answer: answer = 12
5 Correct 1 ms 364 KB Correct answer: answer = 52
6 Correct 1 ms 364 KB Correct answer: answer = 210
7 Correct 1 ms 364 KB Correct answer: answer = 88
8 Correct 1 ms 364 KB Correct answer: answer = 7696
9 Correct 1 ms 364 KB Correct answer: answer = 1
10 Correct 1 ms 364 KB Correct answer: answer = 2374
11 Correct 1 ms 364 KB Correct answer: answer = 9502
12 Correct 1 ms 364 KB Correct answer: answer = 49
13 Correct 1 ms 364 KB Correct answer: answer = 151
14 Correct 1 ms 364 KB Correct answer: answer = 7550
15 Correct 1 ms 364 KB Correct answer: answer = 7220
16 Correct 1 ms 364 KB Correct answer: answer = 7550
17 Correct 1 ms 364 KB Correct answer: answer = 10000
18 Correct 1 ms 364 KB Correct answer: answer = 10000
19 Correct 1 ms 364 KB Correct answer: answer = 624
20 Correct 1 ms 320 KB Correct answer: answer = 10000
21 Correct 1 ms 364 KB Correct answer: answer = 1
22 Correct 1 ms 364 KB Correct answer: answer = 4
23 Correct 1 ms 364 KB Correct answer: answer = 1
24 Correct 1 ms 364 KB Correct answer: answer = 5
25 Correct 1 ms 364 KB Correct answer: answer = 41
26 Correct 1 ms 364 KB Correct answer: answer = 71923
27 Correct 2 ms 364 KB Correct answer: answer = 77137
28 Correct 2 ms 384 KB Correct answer: answer = 764
29 Correct 2 ms 364 KB Correct answer: answer = 250000
30 Correct 3 ms 364 KB Correct answer: answer = 500
31 Correct 1 ms 364 KB Correct answer: answer = 32
32 Correct 2 ms 364 KB Correct answer: answer = 130050
33 Correct 3 ms 364 KB Correct answer: answer = 5110
34 Correct 2 ms 364 KB Correct answer: answer = 2626
35 Correct 2 ms 364 KB Correct answer: answer = 796
36 Correct 3 ms 364 KB Correct answer: answer = 7580
37 Correct 3 ms 364 KB Correct answer: answer = 1904
38 Correct 2 ms 364 KB Correct answer: answer = 996004
39 Correct 2 ms 364 KB Correct answer: answer = 38817
40 Correct 2 ms 364 KB Correct answer: answer = 4096
41 Correct 1 ms 364 KB Correct answer: answer = 1
42 Correct 1 ms 364 KB Correct answer: answer = 1
43 Correct 3 ms 364 KB Correct answer: answer = 2040
44 Correct 1 ms 364 KB Correct answer: answer = 2
45 Correct 1 ms 364 KB Correct answer: answer = 4
46 Correct 1 ms 364 KB Correct answer: answer = 9
47 Correct 1 ms 364 KB Correct answer: answer = 9
48 Correct 1 ms 364 KB Correct answer: answer = 21
49 Correct 1 ms 364 KB Correct answer: answer = 71
50 Correct 1 ms 364 KB Correct answer: answer = 77
51 Correct 1 ms 364 KB Correct answer: answer = 400
52 Correct 1 ms 364 KB Correct answer: answer = 996004
53 Correct 1 ms 364 KB Correct answer: answer = 997310
54 Correct 1 ms 364 KB Correct answer: answer = 990781
55 Correct 1 ms 364 KB Correct answer: answer = 996545
56 Correct 1 ms 364 KB Correct answer: answer = 484
57 Correct 1 ms 364 KB Correct answer: answer = 484
58 Correct 3 ms 364 KB Correct answer: answer = 63501
59 Correct 3 ms 364 KB Correct answer: answer = 323501
60 Correct 3 ms 364 KB Correct answer: answer = 752500
61 Correct 2 ms 364 KB Correct answer: answer = 761480
62 Correct 2 ms 364 KB Correct answer: answer = 758932
63 Correct 1 ms 364 KB Correct answer: answer = 1000000
64 Correct 3 ms 364 KB Correct answer: answer = 750500
65 Correct 1 ms 364 KB Correct answer: answer = 1000000
66 Correct 1 ms 364 KB Correct answer: answer = 250000
67 Correct 1 ms 364 KB Correct answer: answer = 250000
68 Correct 2 ms 364 KB Correct answer: answer = 1000000
69 Correct 1 ms 364 KB Correct answer: answer = 994009
70 Correct 2 ms 364 KB Correct answer: answer = 59315
71 Correct 2 ms 364 KB Correct answer: answer = 25454
72 Correct 2 ms 364 KB Correct answer: answer = 1504
73 Correct 1 ms 364 KB Correct answer: answer = 37486
74 Correct 2 ms 364 KB Correct answer: answer = 4284
75 Correct 1 ms 364 KB Correct answer: answer = 158008
76 Correct 1 ms 376 KB Correct answer: answer = 51860
77 Correct 1 ms 364 KB Correct answer: answer = 12985
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Correct answer: answer = 4
2 Correct 1 ms 364 KB Correct answer: answer = 4
3 Correct 1 ms 364 KB Correct answer: answer = 4
4 Correct 1 ms 364 KB Correct answer: answer = 12
5 Correct 1 ms 364 KB Correct answer: answer = 52
6 Correct 1 ms 364 KB Correct answer: answer = 210
7 Correct 1 ms 364 KB Correct answer: answer = 88
8 Correct 1 ms 364 KB Correct answer: answer = 7696
9 Correct 1 ms 364 KB Correct answer: answer = 1
10 Correct 1 ms 364 KB Correct answer: answer = 2374
11 Correct 1 ms 364 KB Correct answer: answer = 9502
12 Correct 1 ms 364 KB Correct answer: answer = 49
13 Correct 1 ms 364 KB Correct answer: answer = 151
14 Correct 1 ms 364 KB Correct answer: answer = 7550
15 Correct 1 ms 364 KB Correct answer: answer = 7220
16 Correct 1 ms 364 KB Correct answer: answer = 7550
17 Correct 1 ms 364 KB Correct answer: answer = 10000
18 Correct 1 ms 364 KB Correct answer: answer = 10000
19 Correct 1 ms 364 KB Correct answer: answer = 624
20 Correct 1 ms 320 KB Correct answer: answer = 10000
21 Correct 1 ms 364 KB Correct answer: answer = 1
22 Correct 1 ms 364 KB Correct answer: answer = 4
23 Correct 1 ms 364 KB Correct answer: answer = 1
24 Correct 1 ms 364 KB Correct answer: answer = 5
25 Correct 1 ms 364 KB Correct answer: answer = 41
26 Correct 1 ms 364 KB Correct answer: answer = 71923
27 Correct 2 ms 364 KB Correct answer: answer = 77137
28 Correct 2 ms 384 KB Correct answer: answer = 764
29 Correct 2 ms 364 KB Correct answer: answer = 250000
30 Correct 3 ms 364 KB Correct answer: answer = 500
31 Correct 1 ms 364 KB Correct answer: answer = 32
32 Correct 2 ms 364 KB Correct answer: answer = 130050
33 Correct 3 ms 364 KB Correct answer: answer = 5110
34 Correct 2 ms 364 KB Correct answer: answer = 2626
35 Correct 2 ms 364 KB Correct answer: answer = 796
36 Correct 3 ms 364 KB Correct answer: answer = 7580
37 Correct 3 ms 364 KB Correct answer: answer = 1904
38 Correct 2 ms 364 KB Correct answer: answer = 996004
39 Correct 2 ms 364 KB Correct answer: answer = 38817
40 Correct 2 ms 364 KB Correct answer: answer = 4096
41 Correct 1 ms 364 KB Correct answer: answer = 1
42 Correct 1 ms 364 KB Correct answer: answer = 1
43 Correct 3 ms 364 KB Correct answer: answer = 2040
44 Correct 1 ms 364 KB Correct answer: answer = 2
45 Correct 1 ms 364 KB Correct answer: answer = 4
46 Correct 1 ms 364 KB Correct answer: answer = 9
47 Correct 1 ms 364 KB Correct answer: answer = 9
48 Correct 1 ms 364 KB Correct answer: answer = 21
49 Correct 1 ms 364 KB Correct answer: answer = 71
50 Correct 1 ms 364 KB Correct answer: answer = 77
51 Correct 1 ms 364 KB Correct answer: answer = 400
52 Correct 1 ms 364 KB Correct answer: answer = 996004
53 Correct 1 ms 364 KB Correct answer: answer = 997310
54 Correct 1 ms 364 KB Correct answer: answer = 990781
55 Correct 1 ms 364 KB Correct answer: answer = 996545
56 Correct 1 ms 364 KB Correct answer: answer = 484
57 Correct 1 ms 364 KB Correct answer: answer = 484
58 Correct 3 ms 364 KB Correct answer: answer = 63501
59 Correct 3 ms 364 KB Correct answer: answer = 323501
60 Correct 3 ms 364 KB Correct answer: answer = 752500
61 Correct 2 ms 364 KB Correct answer: answer = 761480
62 Correct 2 ms 364 KB Correct answer: answer = 758932
63 Correct 1 ms 364 KB Correct answer: answer = 1000000
64 Correct 3 ms 364 KB Correct answer: answer = 750500
65 Correct 1 ms 364 KB Correct answer: answer = 1000000
66 Correct 1 ms 364 KB Correct answer: answer = 250000
67 Correct 1 ms 364 KB Correct answer: answer = 250000
68 Correct 2 ms 364 KB Correct answer: answer = 1000000
69 Correct 1 ms 364 KB Correct answer: answer = 994009
70 Correct 2 ms 364 KB Correct answer: answer = 59315
71 Correct 2 ms 364 KB Correct answer: answer = 25454
72 Correct 2 ms 364 KB Correct answer: answer = 1504
73 Correct 1 ms 364 KB Correct answer: answer = 37486
74 Correct 2 ms 364 KB Correct answer: answer = 4284
75 Correct 1 ms 364 KB Correct answer: answer = 158008
76 Correct 1 ms 376 KB Correct answer: answer = 51860
77 Correct 1 ms 364 KB Correct answer: answer = 12985
78 Correct 5 ms 4332 KB Correct answer: answer = 997864126212
79 Correct 5 ms 4332 KB Correct answer: answer = 998608411647
80 Correct 5 ms 4332 KB Correct answer: answer = 995265560477
81 Correct 19 ms 904 KB Correct answer: answer = 10125000
82 Correct 24 ms 904 KB Correct answer: answer = 2291668
83 Correct 12 ms 640 KB Correct answer: answer = 42388
84 Correct 11 ms 620 KB Correct answer: answer = 10318
85 Correct 11 ms 620 KB Correct answer: answer = 3416
86 Correct 34 ms 4716 KB Correct answer: answer = 331708193881
87 Correct 39 ms 4716 KB Correct answer: answer = 2861193756
88 Correct 45 ms 4716 KB Correct answer: answer = 114646930
89 Correct 25 ms 904 KB Correct answer: answer = 9280921
90 Correct 37 ms 4796 KB Correct answer: answer = 999984053400
91 Correct 41 ms 4716 KB Correct answer: answer = 750935949134
92 Correct 5 ms 4332 KB Correct answer: answer = 1000000000000
93 Correct 5 ms 4332 KB Correct answer: answer = 998762383161
94 Correct 36 ms 4716 KB Correct answer: answer = 23017412908
95 Correct 5 ms 4332 KB Correct answer: answer = 728143410622
96 Correct 5 ms 4332 KB Correct answer: answer = 2
97 Correct 37 ms 4796 KB Correct answer: answer = 1824916
98 Correct 30 ms 1132 KB Correct answer: answer = 10680029
99 Correct 33 ms 1260 KB Correct answer: answer = 18351700
100 Correct 30 ms 4796 KB Correct answer: answer = 16040026
101 Correct 7 ms 4332 KB Correct answer: answer = 253968628325
102 Correct 12 ms 620 KB Correct answer: answer = 10267
103 Correct 34 ms 2796 KB Correct answer: answer = 2582408
104 Correct 5 ms 4332 KB Correct answer: answer = 78024964781
105 Correct 5 ms 4332 KB Correct answer: answer = 9866346457
106 Correct 9 ms 4332 KB Correct answer: answer = 3327720949
107 Correct 7 ms 4352 KB Correct answer: answer = 86064128360
108 Correct 10 ms 4332 KB Correct answer: answer = 12698259150
109 Correct 31 ms 4716 KB Correct answer: answer = 1185259288
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Correct answer: answer = 4
2 Correct 1 ms 364 KB Correct answer: answer = 4
3 Correct 1 ms 364 KB Correct answer: answer = 4
4 Correct 1 ms 364 KB Correct answer: answer = 12
5 Correct 1 ms 364 KB Correct answer: answer = 52
6 Correct 1 ms 364 KB Correct answer: answer = 210
7 Correct 1 ms 364 KB Correct answer: answer = 88
8 Correct 1 ms 364 KB Correct answer: answer = 7696
9 Correct 1 ms 364 KB Correct answer: answer = 1
10 Correct 1 ms 364 KB Correct answer: answer = 2374
11 Correct 1 ms 364 KB Correct answer: answer = 9502
12 Correct 1 ms 364 KB Correct answer: answer = 49
13 Correct 1 ms 364 KB Correct answer: answer = 151
14 Correct 1 ms 364 KB Correct answer: answer = 7550
15 Correct 1 ms 364 KB Correct answer: answer = 7220
16 Correct 1 ms 364 KB Correct answer: answer = 7550
17 Correct 1 ms 364 KB Correct answer: answer = 10000
18 Correct 1 ms 364 KB Correct answer: answer = 10000
19 Correct 1 ms 364 KB Correct answer: answer = 624
20 Correct 1 ms 320 KB Correct answer: answer = 10000
21 Correct 1 ms 364 KB Correct answer: answer = 1
22 Correct 1 ms 364 KB Correct answer: answer = 4
23 Correct 1 ms 364 KB Correct answer: answer = 1
24 Correct 1 ms 364 KB Correct answer: answer = 5
25 Correct 1 ms 364 KB Correct answer: answer = 41
26 Correct 1 ms 364 KB Correct answer: answer = 71923
27 Correct 2 ms 364 KB Correct answer: answer = 77137
28 Correct 2 ms 384 KB Correct answer: answer = 764
29 Correct 2 ms 364 KB Correct answer: answer = 250000
30 Correct 3 ms 364 KB Correct answer: answer = 500
31 Correct 1 ms 364 KB Correct answer: answer = 32
32 Correct 2 ms 364 KB Correct answer: answer = 130050
33 Correct 3 ms 364 KB Correct answer: answer = 5110
34 Correct 2 ms 364 KB Correct answer: answer = 2626
35 Correct 2 ms 364 KB Correct answer: answer = 796
36 Correct 3 ms 364 KB Correct answer: answer = 7580
37 Correct 3 ms 364 KB Correct answer: answer = 1904
38 Correct 2 ms 364 KB Correct answer: answer = 996004
39 Correct 2 ms 364 KB Correct answer: answer = 38817
40 Correct 2 ms 364 KB Correct answer: answer = 4096
41 Correct 1 ms 364 KB Correct answer: answer = 1
42 Correct 1 ms 364 KB Correct answer: answer = 1
43 Correct 3 ms 364 KB Correct answer: answer = 2040
44 Correct 1 ms 364 KB Correct answer: answer = 2
45 Correct 1 ms 364 KB Correct answer: answer = 4
46 Correct 1 ms 364 KB Correct answer: answer = 9
47 Correct 1 ms 364 KB Correct answer: answer = 9
48 Correct 1 ms 364 KB Correct answer: answer = 21
49 Correct 1 ms 364 KB Correct answer: answer = 71
50 Correct 1 ms 364 KB Correct answer: answer = 77
51 Correct 1 ms 364 KB Correct answer: answer = 400
52 Correct 1 ms 364 KB Correct answer: answer = 996004
53 Correct 1 ms 364 KB Correct answer: answer = 997310
54 Correct 1 ms 364 KB Correct answer: answer = 990781
55 Correct 1 ms 364 KB Correct answer: answer = 996545
56 Correct 1 ms 364 KB Correct answer: answer = 484
57 Correct 1 ms 364 KB Correct answer: answer = 484
58 Correct 3 ms 364 KB Correct answer: answer = 63501
59 Correct 3 ms 364 KB Correct answer: answer = 323501
60 Correct 3 ms 364 KB Correct answer: answer = 752500
61 Correct 2 ms 364 KB Correct answer: answer = 761480
62 Correct 2 ms 364 KB Correct answer: answer = 758932
63 Correct 1 ms 364 KB Correct answer: answer = 1000000
64 Correct 3 ms 364 KB Correct answer: answer = 750500
65 Correct 1 ms 364 KB Correct answer: answer = 1000000
66 Correct 1 ms 364 KB Correct answer: answer = 250000
67 Correct 1 ms 364 KB Correct answer: answer = 250000
68 Correct 2 ms 364 KB Correct answer: answer = 1000000
69 Correct 1 ms 364 KB Correct answer: answer = 994009
70 Correct 2 ms 364 KB Correct answer: answer = 59315
71 Correct 2 ms 364 KB Correct answer: answer = 25454
72 Correct 2 ms 364 KB Correct answer: answer = 1504
73 Correct 1 ms 364 KB Correct answer: answer = 37486
74 Correct 2 ms 364 KB Correct answer: answer = 4284
75 Correct 1 ms 364 KB Correct answer: answer = 158008
76 Correct 1 ms 376 KB Correct answer: answer = 51860
77 Correct 1 ms 364 KB Correct answer: answer = 12985
78 Correct 5 ms 4332 KB Correct answer: answer = 997864126212
79 Correct 5 ms 4332 KB Correct answer: answer = 998608411647
80 Correct 5 ms 4332 KB Correct answer: answer = 995265560477
81 Correct 19 ms 904 KB Correct answer: answer = 10125000
82 Correct 24 ms 904 KB Correct answer: answer = 2291668
83 Correct 12 ms 640 KB Correct answer: answer = 42388
84 Correct 11 ms 620 KB Correct answer: answer = 10318
85 Correct 11 ms 620 KB Correct answer: answer = 3416
86 Correct 34 ms 4716 KB Correct answer: answer = 331708193881
87 Correct 39 ms 4716 KB Correct answer: answer = 2861193756
88 Correct 45 ms 4716 KB Correct answer: answer = 114646930
89 Correct 25 ms 904 KB Correct answer: answer = 9280921
90 Correct 37 ms 4796 KB Correct answer: answer = 999984053400
91 Correct 41 ms 4716 KB Correct answer: answer = 750935949134
92 Correct 5 ms 4332 KB Correct answer: answer = 1000000000000
93 Correct 5 ms 4332 KB Correct answer: answer = 998762383161
94 Correct 36 ms 4716 KB Correct answer: answer = 23017412908
95 Correct 5 ms 4332 KB Correct answer: answer = 728143410622
96 Correct 5 ms 4332 KB Correct answer: answer = 2
97 Correct 37 ms 4796 KB Correct answer: answer = 1824916
98 Correct 30 ms 1132 KB Correct answer: answer = 10680029
99 Correct 33 ms 1260 KB Correct answer: answer = 18351700
100 Correct 30 ms 4796 KB Correct answer: answer = 16040026
101 Correct 7 ms 4332 KB Correct answer: answer = 253968628325
102 Correct 12 ms 620 KB Correct answer: answer = 10267
103 Correct 34 ms 2796 KB Correct answer: answer = 2582408
104 Correct 5 ms 4332 KB Correct answer: answer = 78024964781
105 Correct 5 ms 4332 KB Correct answer: answer = 9866346457
106 Correct 9 ms 4332 KB Correct answer: answer = 3327720949
107 Correct 7 ms 4352 KB Correct answer: answer = 86064128360
108 Correct 10 ms 4332 KB Correct answer: answer = 12698259150
109 Correct 31 ms 4716 KB Correct answer: answer = 1185259288
110 Correct 17 ms 4972 KB Correct answer: answer = 999889968863
111 Correct 17 ms 4972 KB Correct answer: answer = 999861384931
112 Correct 17 ms 4972 KB Correct answer: answer = 999811809929
113 Correct 18 ms 4972 KB Correct answer: answer = 999869756441
114 Correct 420 ms 7020 KB Correct answer: answer = 1700000000
115 Correct 553 ms 7268 KB Correct answer: answer = 131666670
116 Correct 124 ms 2504 KB Correct answer: answer = 89478486
117 Correct 161 ms 2620 KB Correct answer: answer = 4971040
118 Correct 143 ms 2508 KB Correct answer: answer = 2711494
119 Correct 584 ms 7008 KB Correct answer: answer = 25252530
120 Correct 571 ms 7012 KB Correct answer: answer = 62500000
121 Correct 522 ms 9696 KB Correct answer: answer = 333175097780
122 Correct 599 ms 9696 KB Correct answer: answer = 33121180179
123 Correct 616 ms 9824 KB Correct answer: answer = 9802314015
124 Correct 570 ms 6900 KB Correct answer: answer = 32567551
125 Correct 740 ms 10724 KB Correct answer: answer = 997525000000
126 Correct 539 ms 9452 KB Correct answer: answer = 752723538884
127 Correct 16 ms 4972 KB Correct answer: answer = 1000000000000
128 Correct 22 ms 5004 KB Correct answer: answer = 999978000121
129 Correct 19 ms 5100 KB Correct answer: answer = 745986144735
130 Correct 13 ms 4972 KB Correct answer: answer = 2
131 Correct 657 ms 10740 KB Correct answer: answer = 277966670
132 Correct 514 ms 10812 KB Correct answer: answer = 2500900082
133 Correct 55 ms 5612 KB Correct answer: answer = 301248349636
134 Correct 263 ms 3532 KB Correct answer: answer = 14118891
135 Correct 18 ms 4972 KB Correct answer: answer = 14384977265
136 Correct 25 ms 5100 KB Correct answer: answer = 3681368330
137 Correct 22 ms 5100 KB Correct answer: answer = 2720316816
# Verdict Execution time Memory Grader output
1 Correct 1 ms 364 KB Correct answer: answer = 4
2 Correct 1 ms 364 KB Correct answer: answer = 4
3 Correct 1 ms 364 KB Correct answer: answer = 4
4 Correct 1 ms 364 KB Correct answer: answer = 12
5 Correct 1 ms 364 KB Correct answer: answer = 52
6 Correct 1 ms 364 KB Correct answer: answer = 210
7 Correct 1 ms 364 KB Correct answer: answer = 88
8 Correct 1 ms 364 KB Correct answer: answer = 7696
9 Correct 1 ms 364 KB Correct answer: answer = 1
10 Correct 1 ms 364 KB Correct answer: answer = 2374
11 Correct 1 ms 364 KB Correct answer: answer = 9502
12 Correct 1 ms 364 KB Correct answer: answer = 49
13 Correct 1 ms 364 KB Correct answer: answer = 151
14 Correct 1 ms 364 KB Correct answer: answer = 7550
15 Correct 1 ms 364 KB Correct answer: answer = 7220
16 Correct 1 ms 364 KB Correct answer: answer = 7550
17 Correct 1 ms 364 KB Correct answer: answer = 10000
18 Correct 1 ms 364 KB Correct answer: answer = 10000
19 Correct 1 ms 364 KB Correct answer: answer = 624
20 Correct 1 ms 320 KB Correct answer: answer = 10000
21 Correct 1 ms 364 KB Correct answer: answer = 1
22 Correct 1 ms 364 KB Correct answer: answer = 4
23 Correct 1 ms 364 KB Correct answer: answer = 1
24 Correct 1 ms 364 KB Correct answer: answer = 5
25 Correct 1 ms 364 KB Correct answer: answer = 41
26 Correct 1 ms 364 KB Correct answer: answer = 71923
27 Correct 2 ms 364 KB Correct answer: answer = 77137
28 Correct 2 ms 384 KB Correct answer: answer = 764
29 Correct 2 ms 364 KB Correct answer: answer = 250000
30 Correct 3 ms 364 KB Correct answer: answer = 500
31 Correct 1 ms 364 KB Correct answer: answer = 32
32 Correct 2 ms 364 KB Correct answer: answer = 130050
33 Correct 3 ms 364 KB Correct answer: answer = 5110
34 Correct 2 ms 364 KB Correct answer: answer = 2626
35 Correct 2 ms 364 KB Correct answer: answer = 796
36 Correct 3 ms 364 KB Correct answer: answer = 7580
37 Correct 3 ms 364 KB Correct answer: answer = 1904
38 Correct 2 ms 364 KB Correct answer: answer = 996004
39 Correct 2 ms 364 KB Correct answer: answer = 38817
40 Correct 2 ms 364 KB Correct answer: answer = 4096
41 Correct 1 ms 364 KB Correct answer: answer = 1
42 Correct 1 ms 364 KB Correct answer: answer = 1
43 Correct 3 ms 364 KB Correct answer: answer = 2040
44 Correct 1 ms 364 KB Correct answer: answer = 2
45 Correct 1 ms 364 KB Correct answer: answer = 4
46 Correct 1 ms 364 KB Correct answer: answer = 9
47 Correct 1 ms 364 KB Correct answer: answer = 9
48 Correct 1 ms 364 KB Correct answer: answer = 21
49 Correct 1 ms 364 KB Correct answer: answer = 71
50 Correct 1 ms 364 KB Correct answer: answer = 77
51 Correct 1 ms 364 KB Correct answer: answer = 400
52 Correct 1 ms 364 KB Correct answer: answer = 996004
53 Correct 1 ms 364 KB Correct answer: answer = 997310
54 Correct 1 ms 364 KB Correct answer: answer = 990781
55 Correct 1 ms 364 KB Correct answer: answer = 996545
56 Correct 1 ms 364 KB Correct answer: answer = 484
57 Correct 1 ms 364 KB Correct answer: answer = 484
58 Correct 3 ms 364 KB Correct answer: answer = 63501
59 Correct 3 ms 364 KB Correct answer: answer = 323501
60 Correct 3 ms 364 KB Correct answer: answer = 752500
61 Correct 2 ms 364 KB Correct answer: answer = 761480
62 Correct 2 ms 364 KB Correct answer: answer = 758932
63 Correct 1 ms 364 KB Correct answer: answer = 1000000
64 Correct 3 ms 364 KB Correct answer: answer = 750500
65 Correct 1 ms 364 KB Correct answer: answer = 1000000
66 Correct 1 ms 364 KB Correct answer: answer = 250000
67 Correct 1 ms 364 KB Correct answer: answer = 250000
68 Correct 2 ms 364 KB Correct answer: answer = 1000000
69 Correct 1 ms 364 KB Correct answer: answer = 994009
70 Correct 2 ms 364 KB Correct answer: answer = 59315
71 Correct 2 ms 364 KB Correct answer: answer = 25454
72 Correct 2 ms 364 KB Correct answer: answer = 1504
73 Correct 1 ms 364 KB Correct answer: answer = 37486
74 Correct 2 ms 364 KB Correct answer: answer = 4284
75 Correct 1 ms 364 KB Correct answer: answer = 158008
76 Correct 1 ms 376 KB Correct answer: answer = 51860
77 Correct 1 ms 364 KB Correct answer: answer = 12985
78 Correct 5 ms 4332 KB Correct answer: answer = 997864126212
79 Correct 5 ms 4332 KB Correct answer: answer = 998608411647
80 Correct 5 ms 4332 KB Correct answer: answer = 995265560477
81 Correct 19 ms 904 KB Correct answer: answer = 10125000
82 Correct 24 ms 904 KB Correct answer: answer = 2291668
83 Correct 12 ms 640 KB Correct answer: answer = 42388
84 Correct 11 ms 620 KB Correct answer: answer = 10318
85 Correct 11 ms 620 KB Correct answer: answer = 3416
86 Correct 34 ms 4716 KB Correct answer: answer = 331708193881
87 Correct 39 ms 4716 KB Correct answer: answer = 2861193756
88 Correct 45 ms 4716 KB Correct answer: answer = 114646930
89 Correct 25 ms 904 KB Correct answer: answer = 9280921
90 Correct 37 ms 4796 KB Correct answer: answer = 999984053400
91 Correct 41 ms 4716 KB Correct answer: answer = 750935949134
92 Correct 5 ms 4332 KB Correct answer: answer = 1000000000000
93 Correct 5 ms 4332 KB Correct answer: answer = 998762383161
94 Correct 36 ms 4716 KB Correct answer: answer = 23017412908
95 Correct 5 ms 4332 KB Correct answer: answer = 728143410622
96 Correct 5 ms 4332 KB Correct answer: answer = 2
97 Correct 37 ms 4796 KB Correct answer: answer = 1824916
98 Correct 30 ms 1132 KB Correct answer: answer = 10680029
99 Correct 33 ms 1260 KB Correct answer: answer = 18351700
100 Correct 30 ms 4796 KB Correct answer: answer = 16040026
101 Correct 7 ms 4332 KB Correct answer: answer = 253968628325
102 Correct 12 ms 620 KB Correct answer: answer = 10267
103 Correct 34 ms 2796 KB Correct answer: answer = 2582408
104 Correct 5 ms 4332 KB Correct answer: answer = 78024964781
105 Correct 5 ms 4332 KB Correct answer: answer = 9866346457
106 Correct 9 ms 4332 KB Correct answer: answer = 3327720949
107 Correct 7 ms 4352 KB Correct answer: answer = 86064128360
108 Correct 10 ms 4332 KB Correct answer: answer = 12698259150
109 Correct 31 ms 4716 KB Correct answer: answer = 1185259288
110 Correct 17 ms 4972 KB Correct answer: answer = 999889968863
111 Correct 17 ms 4972 KB Correct answer: answer = 999861384931
112 Correct 17 ms 4972 KB Correct answer: answer = 999811809929
113 Correct 18 ms 4972 KB Correct answer: answer = 999869756441
114 Correct 420 ms 7020 KB Correct answer: answer = 1700000000
115 Correct 553 ms 7268 KB Correct answer: answer = 131666670
116 Correct 124 ms 2504 KB Correct answer: answer = 89478486
117 Correct 161 ms 2620 KB Correct answer: answer = 4971040
118 Correct 143 ms 2508 KB Correct answer: answer = 2711494
119 Correct 584 ms 7008 KB Correct answer: answer = 25252530
120 Correct 571 ms 7012 KB Correct answer: answer = 62500000
121 Correct 522 ms 9696 KB Correct answer: answer = 333175097780
122 Correct 599 ms 9696 KB Correct answer: answer = 33121180179
123 Correct 616 ms 9824 KB Correct answer: answer = 9802314015
124 Correct 570 ms 6900 KB Correct answer: answer = 32567551
125 Correct 740 ms 10724 KB Correct answer: answer = 997525000000
126 Correct 539 ms 9452 KB Correct answer: answer = 752723538884
127 Correct 16 ms 4972 KB Correct answer: answer = 1000000000000
128 Correct 22 ms 5004 KB Correct answer: answer = 999978000121
129 Correct 19 ms 5100 KB Correct answer: answer = 745986144735
130 Correct 13 ms 4972 KB Correct answer: answer = 2
131 Correct 657 ms 10740 KB Correct answer: answer = 277966670
132 Correct 514 ms 10812 KB Correct answer: answer = 2500900082
133 Correct 55 ms 5612 KB Correct answer: answer = 301248349636
134 Correct 263 ms 3532 KB Correct answer: answer = 14118891
135 Correct 18 ms 4972 KB Correct answer: answer = 14384977265
136 Correct 25 ms 5100 KB Correct answer: answer = 3681368330
137 Correct 22 ms 5100 KB Correct answer: answer = 2720316816
138 Correct 31 ms 5740 KB Correct answer: answer = 999976000144
139 Correct 31 ms 5740 KB Correct answer: answer = 999856102410
140 Correct 33 ms 5740 KB Correct answer: answer = 999958401531
141 Correct 30 ms 5740 KB Correct answer: answer = 999769649944
142 Correct 33 ms 5740 KB Correct answer: answer = 999874525918
143 Correct 1027 ms 13368 KB Correct answer: answer = 6050000000
144 Correct 1250 ms 13292 KB Correct answer: answer = 1112500000
145 Correct 619 ms 8884 KB Correct answer: answer = 4294967296
146 Correct 795 ms 9084 KB Correct answer: answer = 87652406
147 Correct 807 ms 9136 KB Correct answer: answer = 6297664
148 Correct 816 ms 9072 KB Correct answer: answer = 196612
149 Correct 1369 ms 13492 KB Correct answer: answer = 15015100
150 Correct 1332 ms 13600 KB Correct answer: answer = 25000000
151 Correct 1049 ms 14940 KB Correct answer: answer = 333230209550
152 Correct 1340 ms 15244 KB Correct answer: answer = 917123769
153 Correct 1379 ms 16980 KB Correct answer: answer = 95162
154 Correct 1314 ms 13424 KB Correct answer: answer = 382616191
155 Correct 1494 ms 16820 KB Correct answer: answer = 990033333400
156 Correct 1500 ms 16836 KB Correct answer: answer = 990000100000
157 Correct 1174 ms 14604 KB Correct answer: answer = 749998188180
158 Correct 26 ms 5740 KB Correct answer: answer = 1000000000000
159 Correct 31 ms 5740 KB Correct answer: answer = 999988000036
160 Correct 35 ms 5868 KB Correct answer: answer = 744929274393
161 Correct 21 ms 5740 KB Correct answer: answer = 2
162 Correct 1477 ms 16968 KB Correct answer: answer = 1300024
163 Correct 1137 ms 17212 KB Correct answer: answer = 5000700010
164 Correct 117 ms 7016 KB Correct answer: answer = 354997100800
165 Correct 601 ms 7224 KB Correct answer: answer = 257000
166 Correct 708 ms 9120 KB Correct answer: answer = 3765323
167 Correct 663 ms 7664 KB Correct answer: answer = 1525903
168 Correct 32 ms 5868 KB Correct answer: answer = 67618137730
169 Correct 32 ms 5868 KB Correct answer: answer = 12656680171
170 Correct 52 ms 6124 KB Correct answer: answer = 579831736
171 Correct 374 ms 8696 KB Correct answer: answer = 23605611
172 Correct 64 ms 6412 KB Correct answer: answer = 7052481200
173 Correct 145 ms 7152 KB Correct answer: answer = 1314039500
174 Correct 247 ms 8184 KB Correct answer: answer = 302484000
175 Correct 860 ms 11968 KB Correct answer: answer = 52348480