QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#761561 | #9568. Left Shifting 3 | flyWang | WA | 5ms | 3728kb | C++23 | 1.5kb | 2024-11-19 00:49:21 | 2024-11-19 00:49:22 |
Judging History
answer
#include<bits/stdc++.h>
#define endl '\n'
#define int long long
#define ld long double
using namespace std;
int dx[] = { -1,-1,0,1,1,1,0,-1 };
int dy[] = { 0,1,1,1,0,-1,-1,-1 };
const int NC = 2e3 + 10;
char ches[NC][NC];
const int mod = 1e9 + 7;
const int N = 2e5 + 10;
int a[N], b[N], n, m,k;
void solve() {
//注意审题吧
cin >> n >> k;
k = min(k,n);
string s; cin >> s;
string t = ' ' + s + s + ' ';
string str = s;
int ans = 0;
for(int i = 0;i + 6 < s.size();++i){
ans += s.substr(i,7) == "nanjing";
}
auto jd = [&](int l,int r) ->bool{
if(r - l + 1 < 7) return false;
return t[r - 6] == 'n' && t[r - 5] == 'a' && t[r - 4] == 'n' &&
t[r - 3] == 'j' && t[r - 2] == 'i' && t[r - 1] == 'n' && t[r] == 'g';
};
auto djd = [&](int l,int r) ->bool{
if(r - l + 1 < 7) return false;
return t[l] == 'n' && t[l + 1] == 'a' && t[l + 2] == 'n' &&
t[l + 3] == 'j' && t[l + 4] == 'i' && t[l + 5] == 'n' && t[l + 6] == 'g';
};
// cerr << "ans = " << ans << endl;
int sz = ans;
for(int i = n + 1,j = 1;i <= 2 * n && j <= k;++i,++j){
sz -= djd(i - n + 1,i);
sz += jd(i - n + 1,i);
ans = max(ans,sz);
}
cout << ans << endl;
}
signed main() {
ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
solve();
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3728kb
input:
4 21 10 jingicpcnanjingsuanan 21 0 jingicpcnanjingsuanan 21 3 nanjingnanjingnanjing 4 100 icpc
output:
2 1 3 0
result:
ok 4 number(s): "2 1 3 0"
Test #2:
score: -100
Wrong Answer
time: 5ms
memory: 3600kb
input:
2130 39 7 nnananjingannanjingngnanjinganjinggjina 1 479084228 g 33 2 gqnanjinggrjdtktnanjingcvsenanjin 24 196055605 ginganjingnanjingnanjing 23 3 ngnanjinganjingjinnanji 40 3 njingaaznannanjingnananjingyonwpnanjinga 40 207842908 nanjinggphconanjingkonanjinannanjinglxna 46 3 ingjingnnanjingnanjinging...
output:
3 0 3 2 1 3 4 4 3 4 0 2 4 3 2 1 1 1 4 2 0 3 3 0 0 1 0 0 0 5 5 0 1 2 1 2 2 1 1 1 3 3 1 3 2 0 1 2 4 1 2 1 2 1 2 3 0 1 0 0 2 1 3 2 2 1 0 3 1 2 1 1 4 4 1 1 1 1 0 1 1 1 1 2 0 4 4 3 1 0 2 1 1 1 1 5 1 4 0 1 2 1 3 4 3 3 3 3 1 3 2 1 3 1 2 0 0 1 0 5 0 2 0 3 1 0 2 2 3 2 1 2 0 1 1 1 2 4 1 3 2 0 1 1 2 2 2 1 0 3 ...
result:
wrong answer 5th numbers differ - expected: '2', found: '1'