ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#349 | #7. 「WyOJ Round 1」归 · 星穗垂野 | WXZY | 100 | 5897ms | 455236kb | C++23 | 2.3kb | 2025-04-21 00:11:32 | 2025-04-21 00:11:33 |
answer
#include<bits/stdc++.h>
using namespace std;
// #define int long long
#define ll long long
// #define PII pair<int,int>
// #define endl '\n'
// #define lson 2*p
// #define rson 2*p+1
const int N=1e5+10;
const int mod=1e9+7;
int rt[N],ls[N*17*18],rs[N*17*18];
ll w[N*17*18],sum[N];
int a[N],tot;
int f[N][19],pw[N],n,C,lg[N];
void init() {
for(int i=1;i<=n;i++) f[i][0]=a[i];
for(int j=1;j<=18;j++) {
for(int i=1;i+pw[j]-1<=n;i++) {
f[i][j]=__gcd(f[i][j-1],f[i+(pw[j-1])][j-1]);
}
}
}
int query(int l,int r) {
int k=lg[r-l+1];
return __gcd(f[l][k],f[r-pw[k]+1][k]);
}
int build(int l,int r) {
tot++;
int root=tot;
if(l==r) {
if(!l) w[root]=0;
else w[root]=1e18;
return tot;
}
int mid=l+r>>1;
ls[root]=build(l,mid);
rs[root]=build(mid+1,r);
w[root]=min(w[ls[root]],w[rs[root]]);
return root;
}
int update(int root,int l,int r,int pos,ll k) {
int res=++tot;
ls[res]=ls[root],rs[res]=rs[root];
w[res]=min(w[root],k);
if(l==r) {
w[res]=min(w[res],k);
return res;
}
int mid=l+r>>1;
if(pos<=mid) ls[res]=update(ls[root],l,mid,pos,k);
else rs[res]=update(rs[root],mid+1,r,pos,k);
return res;
}
ll query(int root,int l,int r,int ql,int qr) {
if(l>=ql&&r<=qr) return w[root];
ll ans=1e18;
int mid=l+r>>1;
if(ql<=mid) ans=min(ans,query(ls[root],l,mid,ql,qr));
if(qr>mid) ans=min(ans,query(rs[root],mid+1,r,ql,qr));
return ans;
}
void solve() {
cin>>n>>C;
for(int i=1;i<=n;i++) cin>>a[i],rt[i]=0;
for(int i=1,x;i<=n;i++) cin>>x,sum[i]=sum[i-1]+x;
init();
tot=0;
rt[0]=build(0,n);
for(int i=1;i<=n;i++) {
int cur=i;
rt[i]=rt[i-1];
while(cur) {
int res=0,l=1,r=cur;
int now=query(cur,i);
while(l<=r) {
int mid=l+r>>1;
if(query(mid,i)==now) res=mid,r=mid-1;
else l=mid+1;
}
if(!res) res=1;
int len=i-res+1;
if(len>=now) {
int j=min(i-now+1,cur);
j=i-j+1;
ll val=query(rt[i-j],0,n,0,now)+now*(sum[i]-sum[i-j])+C;
rt[i]=update(rt[i],0,n,j,val);
}
cur=res-1;
}
}
cout<<query(rt[n],0,n,1,n)<<endl;
}
signed main() {
int T=1;
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
lg[0]=-1;
for(int i=1;i<=1e5;i++) lg[i]=lg[i/2]+1;
pw[0]=1;
for(int i=1;i<=20;i++) pw[i]=pw[i-1]*2;
cin>>T;
while(T--) {
solve();
}
}
这程序好像有点Bug,我给组数据试试?
详细
小提示:点击横条可展开更详细的信息
Test #1:
score: 10
Accepted
time: 11ms
memory: 9892kb
input:
1000 10 -759451753 8 10 5 7 5 10 6 10 2 1 5 6 5 4 9 8 5 4 1 3 10 -953033990 4 10 10 8 8 2 1 7 4 1 0 ...
output:
-2278355214 -2859101918 -21349075 -1203387136 -1290642033 -851981042 -648655823 -1699966984 -1493814...
result:
ok 1000 numbers
Test #2:
score: 10
Accepted
time: 300ms
memory: 54368kb
input:
5 94253 6998801 88374 94432 21568 79110 3746 94223 86214 12083 54743 1622 16110 18595 18994 3665 547...
output:
6999125 764376403 718240695 1381649585 885156744
result:
ok 5 number(s): "6999125 764376403 718240695 1381649585 885156744"
Test #3:
score: 10
Accepted
time: 3ms
memory: 12224kb
input:
5 120 -848255662 53358 95098 92852 36846 80052 83050 44071 22632 50005 52339 7339 38495 66618 6337 5...
output:
-11025209476 -3953017107 -5975377615 -2466586019 -5823678268
result:
ok 5 number(s): "-11025209476 -3953017107 -5975377615 -2466586019 -5823678268"
Test #4:
score: 10
Accepted
time: 4ms
memory: 9924kb
input:
5 100 -964452256 94167 36596 60051 82090 55625 56197 94589 29844 14929 68497 81714 90264 66283 96767...
output:
-7714370390 -19569375783 -554464800 -1059581333 -6827008162
result:
ok 5 number(s): "-7714370390 -19569375783 -554464800 -1059581333 -6827008162"
Test #5:
score: 10
Accepted
time: 12ms
memory: 14264kb
input:
5 984 -715414516 65632 15191 55392 53178 88695 20308 44882 16528 12986 81169 76880 2239 81264 13866 ...
output:
-72952473687 -64021627506 -700730085 -994178012 -1624804963
result:
ok 5 number(s): "-72952473687 -64021627506 -700730085 -994178012 -1624804963"
Test #6:
score: 10
Accepted
time: 1071ms
memory: 386032kb
input:
5 83593 -175988991 46605 26358 5204 30137 41225 11710 75224 14130 56433 62524 29873 59483 22318 2619...
output:
-1656361289384 -4920133073293 -1028097824 -2809116480 -22668175189
result:
ok 5 number(s): "-1656361289384 -4920133073293 ...097824 -2809116480 -22668175189"
Test #7:
score: 10
Accepted
time: 1207ms
memory: 433472kb
input:
5 96302 -451340376 2672 47391 49737 61648 38099 10679 28316 91168 97182 40556 20560 89630 45931 9187...
output:
-4877361987440 -9327808595024 -261498007 97842263 -37427524204
result:
ok 5 number(s): "-4877361987440 -9327808595024 -261498007 97842263 -37427524204"
Test #8:
score: 10
Accepted
time: 1200ms
memory: 455236kb
input:
5 82075 -915749780 41503 94470 21657 60519 10090 65640 80911 29436 63096 68715 79609 87499 26240 606...
output:
-8500967499879 -2162204721519 -803472133 -6968294203 -60694304098
result:
ok 5 number(s): "-8500967499879 -2162204721519 ...472133 -6968294203 -60694304098"
Test #9:
score: 10
Accepted
time: 1057ms
memory: 369424kb
input:
5 86206 -158351237 12910 53574 97622 75378 61116 40492 87106 60678 72614 2146 43673 15147 23123 7469...
output:
-1508037508585 -4714642449519 -3202809425 -6778545312 -12974512083
result:
ok 5 number(s): "-1508037508585 -4714642449519 ...809425 -6778545312 -12974512083"
Test #10:
score: 10
Accepted
time: 1032ms
memory: 365156kb
input:
5 87683 -236086252 88768 76878 54808 98282 70961 83599 48353 34381 40413 95288 24241 74500 52966 994...
output:
-2319782085288 -10990638538852 -1651187059 -12428157994 -22719490815
result:
ok 5 number(s): "-2319782085288 -10990638538852...87059 -12428157994 -22719490815"
Extra Test:
score: 0
Extra Test Passed