ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#169149 | #46. delete | qmh20061363 | 40 | 511ms | 24576kb | C++11 | 1.2kb | 2023-02-23 12:22:14 | 2023-02-23 12:22:14 |
answer
#include<bits/stdc++.h>
using namespace std;
#define open(x) freopen(x ".in", "r", stdin);freopen(x ".out", "w", stdout);
#define int long long
inline int read(){int f=1;int x=0;char c=getchar();while(c<'0'||c>'9'){if(c=='-'){f=-f;}c=getchar();}while(c>='0'&&c<='9'){x=(x<<1)+(x<<3)+(c^48);c=getchar();}return x*f;}
inline void wr(int x){if(x<0){putchar('-');x=-x;}if(x>9){wr(x/10);}putchar(x%10+'0');}
inline int lowbit(int x){
return x & -x;
}
int f[1000050];
int out = 0;
int n,k;
struct node{
int x , id;
bool operator <(const node& y)const{
if(id - x == y.id - y.x){
return id < y.id;
}
else{
return id - x < y.id - y.x;
}
}
}a[1000050];
inline void sum(int x,int v){
while(x <= n){
f[x] = max(v , f[x]);
x+=lowbit(x);
}
return;
}
inline int ask(int x){
int R = 0;
while(x > 0){
R = max(R , f[x]);
x-=lowbit(x);
}
return R;
}
signed main(){
n = read();
k = read();
for(int i = 1 ; i <= n ; ++i){
a[i].x = read();
a[i].id = i;
}
sort(a + 1 , a + n + 1);
for(int i = 1 ; i <= n ;++i){
if(a[i].id - a[i].x < 0 || a[i].id -a[i].x > k){
continue;
}
int ans = ask(a[i].x - 1) + 1;
out = max(out ,ans);
sum(a[i].x , ans);
}
wr(out);
return 0;
}
详细
小提示:点击横条可展开更详细的信息
Test #1:
score: 10
Accepted
time: 0ms
memory: 1140kb
input:
20 8 11 9 10 2 4 8 7 4 9 8 12 1 3 12 7 9 9 16 3 15
output:
4
result:
ok single line: '4'
Test #2:
score: 10
Accepted
time: 0ms
memory: 1144kb
input:
20 10 1 12 11 1 2 7 10 2 13 4 11 14 8 15 4 6 1 3 5 12
output:
4
result:
ok single line: '4'
Test #3:
score: 10
Accepted
time: 0ms
memory: 1152kb
input:
500 150 7 2 11 5 1 13 10 10 14 20 20 2 5 17 14 4 5 5 3 2 2 7 10 3 18 2 7 3 5 15 2 8 5 14 3 1 1 4 19 ...
output:
27
result:
ok single line: '27'
Test #4:
score: 10
Accepted
time: 0ms
memory: 1152kb
input:
500 233 8 16 14 3 7 1 14 15 11 8 4 11 13 6 5 18 2 11 10 5 7 3 14 2 7 16 6 5 14 1 13 6 9 7 9 5 5 6 2 ...
output:
26
result:
ok single line: '26'
Test #5:
score: 0
Wrong Answer
time: 0ms
memory: 1260kb
input:
5000 1666 15 23 11 4 10 16 24 9 10 10 9 14 7 3 1 22 4 8 7 18 3 24 19 6 2 16 2 5 7 10 6 12 1 6 18 9 6...
output:
139
result:
wrong answer 1st lines differ - expected: '120', found: '139'
Test #6:
score: 0
Wrong Answer
time: 0ms
memory: 1256kb
input:
5000 2333 2 28 15 6 10 2 10 10 26 7 8 16 3 1 15 17 11 7 8 2 8 2 6 3 4 13 6 20 13 18 3 6 24 1 5 26 18...
output:
144
result:
wrong answer 1st lines differ - expected: '120', found: '144'
Test #7:
score: 0
Wrong Answer
time: 16ms
memory: 3484kb
input:
100000 23333 158 127 191 174 144 43 80 135 48 54 91 22 135 145 32 109 180 16 51 47 86 69 26 121 161 ...
output:
681
result:
wrong answer 1st lines differ - expected: '596', found: '681'
Test #8:
score: 0
Wrong Answer
time: 20ms
memory: 3480kb
input:
100000 55555 81 122 1 146 76 142 36 207 127 17 5 102 123 42 69 15 42 137 94 107 101 49 179 44 48 78 ...
output:
678
result:
wrong answer 1st lines differ - expected: '444', found: '678'
Test #9:
score: 0
Wrong Answer
time: 247ms
memory: 24572kb
input:
1000000 233333 536 132 387 278 660 779 239 1629 535 1641 1374 532 53 840 432 180 1457 232 494 580 61...
output:
2080
result:
wrong answer 1st lines differ - expected: '1819', found: '2080'
Test #10:
score: 0
Wrong Answer
time: 228ms
memory: 24576kb
input:
1000000 666666 1053 405 264 292 1304 414 58 948 985 1112 865 1225 982 595 927 701 623 666 43 1019 43...
output:
2062
result:
wrong answer 1st lines differ - expected: '1187', found: '2062'