QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#684755 | #9258. Huawei Frequencies Selection | xw75pyh | RE | 2ms | 9488kb | C++14 | 1.6kb | 2024-10-28 15:37:37 | 2024-10-28 15:37:37 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int Maxn=2e2+10;
const int Maxm=1e3+10;
const int N=5e5+10;
const int M=5e5+10;
const int mod=1e9+7;
inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')f=-1;ch=getchar();
}
while(ch>='0'&&ch<='9'){
x=(x<<3)+(x<<1)+(ch^48);ch=getchar();
}
return x*f;
}
inline void write(int x){
if(x<0){
x=-x;putchar('-');
}
if(x>9)write(x/10);
putchar(x%10+'0');
}
inline int ksm(int a,int b){
int ans=1;
while(b){
if(b&1)ans=ans*a%mod;b>>=1;a=a*a%mod;
}
return ans;
}
int n,k;int a[M];int op;
deque<int>q;int dp[M];
signed main(){
n=read(),k=read();
for(int i=1;i<=n;i++){
a[i]=read();
if(!a[i])op++;
}
if(op>=k){
write(0);return 0;
}q.push_back(0);
memset(dp,-1,sizeof dp);dp[1]=0;
int mx=-1;
for(int i=2,j=0,k=0;i<=n+1;i++){
if(a[i-1]==1){
while(j<i-1){
j++;
mx=max(mx,dp[j]);
}
}
if(a[i-1]==0){
k=i;
while(!q.empty()&&q.front()<k){
q.pop_front();
}
}
dp[i]=mx;
if(!q.empty()){
dp[i]=max(dp[i],dp[q.front()]);
}
if(dp[i]>=0)dp[i]++;
while(!q.empty()&&dp[i]>=dp[q.back()]){
q.pop_back();
}
q.push_back(i);
}
if(k<=dp[n+1]){
write(1);
return 0;
}
int sum=0;
for(int i=1;i<=n;i++){
if(a[i]==2){
sum++;
}
}
if(sum>0){
write(2);
return 0;
}
int lst=-1;
int res=0;
for(int i=1;i<=n;i++){
if(a[i]<=1){
if(a[i]!=lst){
res++;
}
lst=a[i];
}
}
if(k>=res){
write(2);return 0;
}
write(3);
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 9440kb
input:
2 2 0 2
output:
2
result:
ok answer is '2'
Test #2:
score: 0
Accepted
time: 0ms
memory: 7900kb
input:
3 1 2 1 1
output:
1
result:
ok answer is '1'
Test #3:
score: 0
Accepted
time: 1ms
memory: 9036kb
input:
3 2 1 3 0
output:
2
result:
ok answer is '2'
Test #4:
score: 0
Accepted
time: 2ms
memory: 9488kb
input:
20 15 1 2 2 0 3 3 2 2 2 0 1 1 2 1 3 1 0 2 2 1
output:
1
result:
ok answer is '1'
Test #5:
score: 0
Accepted
time: 1ms
memory: 9112kb
input:
9 4 0 0 2 1 3 1 3 0 3
output:
1
result:
ok answer is '1'
Test #6:
score: 0
Accepted
time: 0ms
memory: 8560kb
input:
19 17 1 0 0 3 0 0 2 3 1 0 3 3 3 1 3 0 0 3 1
output:
2
result:
ok answer is '2'
Test #7:
score: 0
Accepted
time: 1ms
memory: 8132kb
input:
17 15 0 0 3 0 1 1 2 1 2 1 1 1 3 0 0 1 0
output:
2
result:
ok answer is '2'
Test #8:
score: 0
Accepted
time: 1ms
memory: 8284kb
input:
6 5 2 1 3 0 1 0
output:
2
result:
ok answer is '2'
Test #9:
score: 0
Accepted
time: 1ms
memory: 8888kb
input:
16 12 0 2 0 1 2 0 0 0 1 3 3 0 1 0 3 1
output:
2
result:
ok answer is '2'
Test #10:
score: 0
Accepted
time: 1ms
memory: 8268kb
input:
15 9 0 2 2 1 2 0 3 3 1 0 1 1 1 0 1
output:
2
result:
ok answer is '2'
Test #11:
score: 0
Accepted
time: 1ms
memory: 8264kb
input:
8 6 0 0 0 1 0 1 0 1
output:
2
result:
ok answer is '2'
Test #12:
score: 0
Accepted
time: 1ms
memory: 9280kb
input:
10 6 1 0 0 1 0 1 0 3 3 0
output:
2
result:
ok answer is '2'
Test #13:
score: 0
Accepted
time: 1ms
memory: 5820kb
input:
1 1 0
output:
0
result:
ok answer is '0'
Test #14:
score: 0
Accepted
time: 1ms
memory: 9264kb
input:
1 1 1
output:
1
result:
ok answer is '1'
Test #15:
score: 0
Accepted
time: 1ms
memory: 9164kb
input:
7 4 0 1 0 2 1 3 0
output:
2
result:
ok answer is '2'
Test #16:
score: 0
Accepted
time: 1ms
memory: 7848kb
input:
8 5 1 0 1 0 2 1 3 0
output:
2
result:
ok answer is '2'
Test #17:
score: -100
Runtime Error
input:
1000000 1000000 507624 225615 645997 324384 930930 165669 488080 968655 530722 293286 929521 65826 242278 483915 447838 683484 757911 811652 223115 648468 287602 113125 150435 645440 413280 788127 48622 967532 334599 130555 888316 315597 102200 535955 54735 505596 746579 99783 536797 245479 758694 9...