제출 #311121

#제출 시각아이디문제언어결과실행 시간메모리
311121milisav비스킷 담기 (IOI20_biscuits)C++14
12 / 100
22 ms432 KiB
#include<bits/stdc++.h> #include "biscuits.h" using namespace std; long long count_tastiness(long long x, std::vector<long long> a) { long long t[70]; long long psum[70]; long long deg[70]; int k=60; while(a.size()<k) a.push_back(0); for(long long i=0;i<k;i++) { t[i]=0; psum[i]=0; deg[i]=(1ll<<i); } psum[0]=a[0]; for(int i=1;i<k;i++) psum[i]=psum[i-1]+a[i]*deg[i]; for(int i=0;i<k;i++) { if(i==0) { if(a[i]>=x) t[i]=2; else t[i]=1; } else { if(a[i]>=x) t[i]=2*t[i-1]; else { long long nec=(x-a[i])*deg[i]; long long tot=0; long long up=deg[i]-1; for(int j=i-1;j>=0;j--) { long long ls=min((psum[j]-nec)/x,up); if(ls>=deg[j]) { tot=tot+((j==0) ? 1 : t[j-1]); up=min(up,ls-deg[j]); } nec=max(0ll,nec-a[j]*deg[j]); } t[i]=t[i-1]+tot+(nec==0 && up>=0); } } } return t[k-1]; } /*int main() { int q; assert(scanf("%d", &q) == 1); vector<int> k(q); vector<long long> x(q); vector<vector<long long>> a(q); vector<long long> results(q); for (int t = 0; t < q; t++) { assert(scanf("%d%lld", &k[t], &x[t]) == 2); a[t] = vector<long long>(k[t]); for (int i = 0; i < k[t]; i++) { assert(scanf("%lld", &a[t][i]) == 1); } } fclose(stdin); for (int t = 0; t < q; t++) { results[t] = count_tastiness(x[t], a[t]); } for (int t = 0; t < q; t++) { printf("%lld\n", results[t]); } fclose(stdout); return 0; }*/

컴파일 시 표준 에러 (stderr) 메시지

biscuits.cpp: In function 'long long int count_tastiness(long long int, std::vector<long long int>)':
biscuits.cpp:10:19: warning: comparison of integer expressions of different signedness: 'std::vector<long long int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   10 |     while(a.size()<k) a.push_back(0);
      |           ~~~~~~~~^~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...