QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#866139 | #7304. Coins 2 | Invincible | AC ✓ | 156ms | 9560kb | C++23 | 2.0kb | 2025-01-22 12:48:48 | 2025-01-22 12:48:54 |
Judging History
answer
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <iostream>
#include <vector>
#include <set>
#include <queue>
#include <map>
#include <ctime>
#include <random>
#include <cassert>
#include <numeric>
#include <cmath>
#include <bitset>
#include <ext/pb_ds/assoc_container.hpp>
#define pii pair<int, int>
#define fi first
#define se second
#define MP make_pair
#define ep emplace
#define eb emplace_back
//#define int long long
#define rep(i, j, k) for (int i = (j); i <= (k); i++)
#define per(i, j, k) for (int i = (j); i >= (k); i--)
typedef double db;
typedef long double ldb;
typedef long long ll;
//typedef __int128 lll;
typedef unsigned long long ull;
typedef unsigned int ui;
using namespace std;
using namespace __gnu_pbds;
bool Mbe;
//char buf[1<<20],*p1,*p2;
//#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf,1,1<<20,stdin), p1 == p2) ? 0 : *p1++)
int read() {
int s = 0, f = 1;
char c = getchar();
while (c < '0' || c > '9') f ^= (c == '-'), c = getchar();
while (c >= '0' && c <= '9') s = s * 10 + c - '0', c = getchar();
return f ? s : -s;
}
template<typename T>void chkmax(T&x,const T&y){if(x<y)x=y;}
template<typename T>void chkmin(T&x,const T&y){if(x>y)x=y;}
int n,a[20],m;
ll sum,ans;
bool f[5765765];
void Knapsack(int lim){
memset(f,0,lim+1);
f[0]=1;
rep(i,1,n)if(a[i]){
rep(j,0,i-1){
int lst=-1;
for(int k=j;k<=lim;k+=i){
if(f[k])lst=k;
if(~lst&&(k-lst)/i<=a[i])f[k]=1;
}
}
}
}
bool Med;
signed main() {
fprintf(stderr,"%.3lfMb\n",(&Mbe-&Med)/1024./1024.);
while(scanf("%d",&n)==1){
m=1,sum=ans=0;
rep(i,1,n)sum+=(ll)i*(a[i]=read());
rep(i,1,n)m=m*i/__gcd(i,m);
Knapsack(min((ll)(n+1)*m-1,sum));
rep(i,0,n*m-1)ans+=f[i]*((i<=sum)+(sum-i>=n*m));
int tmp=0;
rep(i,n*m,(n+1)*m-1)tmp+=f[i];
if(sum>=2*n*m){
ll dif=sum+1-2*n*m;
ans+=(ll)dif/m*tmp;
rep(i,1,dif%m)ans+=f[n*m+i-1];
}
printf("%lld\n",ans);
}
return 0;
}
这程序好像有点Bug,我给组数据试试?
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3840kb
input:
3 0 1 2 3 0 2 3
output:
6 12
result:
ok 2 number(s): "6 12"
Test #2:
score: 0
Accepted
time: 156ms
memory: 9492kb
input:
1 0 15 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000
output:
1 120000000001
result:
ok 2 number(s): "1 120000000001"
Test #3:
score: 0
Accepted
time: 0ms
memory: 3968kb
input:
5 0 2 1 0 0 5 0 0 0 0 53 5 0 6 3 0 0 5 1 0 0 0 1 5 1 0 0 0 0 5 2 0 0 0 116 5 2 0 0 0 0 5 1 0 1 106 1356 5 0 2 0 0 7926 5 0 0 2 1 2004 5 1 0 0 0 1 5 0 0 0 1 5 5 0 0 0 0 0 5 0 1 32840 0 1 5 2 0 0 0 12 5 2 0 0 1 1 5 0 1 79 56770 10 5 1 0 0 1 0 5 0 1 1 2 52165 5 0 0 0 0 1 5 0 0 1 13 0 5 0 0 0 1 10 5 0 0...
output:
6 54 20 4 2 351 3 7207 23781 10027 4 12 1 98524 39 10 227368 4 260837 2 28 22 114 78 76 4 280 233 8 1 12 214572 10 2 1 1 2 108 17760 15926 250077 55576 4 104 282 45419 1687 2973 8 28482 6 4 2988 8 10 102 4 793 69 2 7624 4 181850 84 36589 3 2832 11 25 2 32457 127 33099 2 3 8 116 4 6 260 4 6 29027 4 2...
result:
ok 100 numbers
Test #4:
score: 0
Accepted
time: 1ms
memory: 3840kb
input:
5 0 0 0 0 7282 5 1 0 1 1 1 5 0 100 1 6466 131627995 5 2 0 0 0 1 5 2 0 0 0 0 5 0 0 0 0 2 5 3 0 0 0 24 5 1 0 0 0 0 5 2 0 0 1033661 1 5 2 0 0 0 1 5 1 0 2 1 0 5 1 0 0 74999942 1 5 0 0 16 5 1 5 0 0 14 1 1 5 0 0 0 94148 2 5 1 0 0 0 0 5 0 4 66108 1 1 5 0 0 0 1 0 5 0 2 0 0 0 5 0 0 26609277 2057266 32110772 ...
output:
7283 12 658166041 6 3 3 100 2 4134650 6 10 224999830 70 48 282447 2 198340 2 3 248610752 3064 6608762 27104217 88460 1225544 2128 206314 4247620 4756202 2 43189704 4 23417 1151 10 174058 1073133147 4852 2 2 10 77870412 6 13616297 6040750 624815262 1854 300636553 1 4 6 31145401 935098 6 82785138 132 ...
result:
ok 100 numbers
Test #5:
score: 0
Accepted
time: 20ms
memory: 3968kb
input:
10 0 0 0 133395012 1 64 1 1 1 29 10 1 0 0 2871 869717 68 15569 112946 431 0 10 2 0 0 0 0 0 0 0 1 1 10 1 0 0 0 0 0 1 1 1 1 10 0 0 0 0 0 0 0 0 0 1 10 0 208 3 0 60131558 184254 1 909 166293 1 10 1 0 0 0 0 0 0 0 0 24784 10 1 0 0 0 1 1 1 26206816 1 0 10 4 0 0 0 0 62468533 1052 0 0 27715813 10 0 0 0 0 0 0...
output:
533580746 5376905 10 20 2 303267664 49570 209654551 651976695 111 9859639 4237557 3045713 509037116 305067 6 25 1852794 2398551872 1651057262 22708645 245970222 110782837 385654273 724791161 56 4 666 100200177 44102430 1298591 9 110583641 7717333 20 612738350 455682 2857417747 135486 4 1103222425 35...
result:
ok 100 numbers
Test #6:
score: 0
Accepted
time: 11ms
memory: 4608kb
input:
15 6 0 0 0 0 0 0 0 0 0 0 0 51010 0 1
output:
459104
result:
ok 1 number(s): "459104"
Test #7:
score: 0
Accepted
time: 66ms
memory: 9560kb
input:
15 6 0 0 0 0 0 0 0 0 15052 1 0 6920899 1 639
output:
90131818
result:
ok 1 number(s): "90131818"
Test #8:
score: 0
Accepted
time: 105ms
memory: 9472kb
input:
15 3 0 0 0 3 43 2 0 6 3916571 0 4106 25560554 1 44
output:
371503201
result:
ok 1 number(s): "371503201"
Test #9:
score: 0
Accepted
time: 7ms
memory: 3968kb
input:
15 9 0 0 0 0 0 0 0 0 0 1 1 352 51 0
output:
5321
result:
ok 1 number(s): "5321"
Test #10:
score: 0
Accepted
time: 93ms
memory: 9424kb
input:
15 1 0 0 0 0 0 7 2050510 0 1 6571321 2097618 1349 893 1
output:
113890132
result:
ok 1 number(s): "113890132"
Test #11:
score: 0
Accepted
time: 124ms
memory: 9424kb
input:
15 0 0 90610226 2 1 9005 0 1 9 1 44 19 1 966676 1
output:
285419021
result:
ok 1 number(s): "285419021"
Test #12:
score: 0
Accepted
time: 43ms
memory: 9416kb
input:
15 4 0 0 0 0 0 0 0 0 0 0 0 230110792 158832450 4087
output:
5215155866
result:
ok 1 number(s): "5215155866"
Test #13:
score: 0
Accepted
time: 90ms
memory: 9500kb
input:
15 1 0 0 0 3 0 0 350364383 4859 3618 356965 5942367 175260 1 0
output:
2880508397
result:
ok 1 number(s): "2880508397"
Test #14:
score: 0
Accepted
time: 79ms
memory: 9440kb
input:
15 1 0 0 0 1 0 1 0 53297877 0 1 25736 0 1 54519258
output:
1297778628
result:
ok 1 number(s): "1297778628"
Test #15:
score: 0
Accepted
time: 94ms
memory: 9520kb
input:
15 3 0 0 0 2 2656013 0 0 42 3 33 1 86626609 0 1
output:
1142082805
result:
ok 1 number(s): "1142082805"
Test #16:
score: 0
Accepted
time: 5ms
memory: 3840kb
input:
10 24 0 0 0 0 0 43 41 39 0 10 0 2 16 0 2 0 0 0 0 0 10 8 0 0 0 0 0 6 0 8 0 10 49 0 0 0 0 0 225 117 134 127 10 5 0 0 0 0 0 7 8 0 0 10 4 0 0 0 0 0 9 7 0 0 10 5 0 0 0 0 0 0 0 11 9 10 25 0 0 47 60 64 345 46 102 44 10 13 0 0 0 0 0 0 21 27 29 10 0 0 0 25 17 0 0 0 9 10 10 12 0 0 0 0 0 0 0 8 9 10 4 0 0 0 0 5...
output:
1005 61 123 5037 117 118 183 5039 715 355 175 185 93 353 279 720 87 194 173 1259 145 555 5038 171 182 151 137 710 1007 189 713 187 5035 137 145 118 173 147 177 171 1001 713 163 708 175 341 190 119 719 57 143 73 694 2519 715 90 5039 137 111 140 1677 5035 177 5041 171 70 161 1005 179 5035 175 171 109 ...
result:
ok 100 numbers
Extra Test:
score: 0
Extra Test Passed