标签:复杂 out can tput pen output pre 游戏 pac
Tgopknight决定使用他的幸运数字2和3来进行这个游戏,他一开始有n个数字,记为{dn}需要 进行k次操作,每次操作找到最小的x使得dx = 2并且dx+1 = 3,此时如果x为奇数,则令dx+i = 2,反之令dx = 3,若没有这样的x则数字不变。
Tgopknight现在想知道进行完所有操作后这些数字变成了什么。
input
本题有多组数据。
每组数据第一行是两个正整数n和k分别表示数字个数和操作次数。
第二行有n个数字,数字之间没有空格。
output
对于每组数据,输出一行,为操作进行完之后的结果。
input
7 2 2343223 4 1 2234
output
2243233 2334
对于前50%的数据n <=104, k <= 104
对于前70%的数据k <= 106
对于 100%的数据1 <= n <=106 ,0 <= k <=109 ,数据组数不超过10
#include <bits/stdc++.h> using namespace std; char s[1000005]; int n, k; int main() { freopen("trans.in","r",stdin); freopen("trans.out","w",stdout); while (~scanf("%d%d%s", &n, &k, s)) { for (int i = 0; i < n && k; i++) { if (s[i]==‘2‘&&s[i+1]==‘3‘&&s[i+2]==‘3‘&&!(i%2)) k%=2; if (k&&s[i]==‘2‘&&s[i+1]==‘3‘) s[i]=s[i+1]=(i%2)?‘3‘:‘2‘,i-=2,k--; } puts(s); } return 0; }
标签:复杂 out can tput pen output pre 游戏 pac
原文地址:http://www.cnblogs.com/bbqub/p/7672559.html