이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <vector>
#include <iostream>
const int maxcount = 10;
const int mask = 1 << maxcount;
const int maxn = 100005;
using namespace std;
int cnt[mask];//popcount array
int f[mask][mask][maxcount+1];
int last[maxn],id[mask][mask][maxcount+1];//store position of last chosen element
int a[maxn],k[maxn];
int n;
int sol[maxn],len;//generate path
int main() {
//freopen("1.in","r",stdin);
cin>>n;
for(int i=1; i<mask; i++) {
cnt[i]=cnt[i>>1]+(i&1);
}
for(int i=1; i<=n; i++) {
cin>>a[i];
}
for(int i=1; i<=n; i++) {
cin>>k[i];
}
int maxid,maxn=0;
for(int i=1; i<=n; i++) {
int cur0=(a[i])>>maxcount,cur1=(a[i])&(mask-1),ans=1;
for(int pre1=0; pre1<mask; pre1++) {
int bc=k[i]-cnt[pre1&cur1];
if(bc>=0 && bc<=maxcount && ans<f[pre1][cur0][bc]+1) {
ans=f[pre1][cur0][bc]+1,last[i]=id[pre1][cur0][bc];
}
}
for(int nex0=0; nex0<mask; nex0++) {
int bc=cnt[nex0&cur0];
if(ans>f[cur1][nex0][bc]) {
f[cur1][nex0][bc]=ans,id[cur1][nex0][bc]=i;
}
}
if(maxn<ans) {
maxn=ans;
maxid=i;
}
}
int cur=maxid;
while(cur) {
sol[++len]=cur;
cur=last[cur];
}
cout<<len<<endl;
for(int i=len;i>=1;i--) {
if(i==1) {
cout<<sol[i]<<endl;
}else{
cout<<sol[i]<<" ";
}
}
}
컴파일 시 표준 에러 (stderr) 메시지
subsequence.cpp: In function 'int main()':
subsequence.cpp:55:6: warning: 'maxid' may be used uninitialized in this function [-Wmaybe-uninitialized]
55 | cur=last[cur];
| ~~~^~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |