题目链接:点击打开链接
题目大意:键盘某些键卡住了,按一次重复 n(题目当中的 k) 次,要求找出可能的键,并且输出正确的字符串顺序。可能的键要求按照被发现的顺序输出。
解题思路:
如果 s[i]==s[i-1],则 cnt++,否则就 cnt%n == 0?若是,则用 vector 记录可能是坏键,为什么可能是,因为有可能一开始是坏键情况,但是最后又不是坏键盘情况,比如:“3 aaasaa”,“a”就不算是坏键。set 用来去重。而unordered_map 用来标记一定不是坏键的键。
最后输出若是坏键,则输出一个,然后 i+=n-1;若不是坏键,则直接输出。
AC 代码
#include<bits/stdc++.h> #include<cmath> #define mem(a,b) memset(a,b,sizeof a); #define INF 0x3f3f3f3f #define MOD 1000000007 using namespace std; typedef long long ll; unordered_map<char,int> ump; vector<char> v; set<char> st; int main() { int n,idx; scanf("%d",&n); string s; cin>>s; char c; int len=s.length(),cnt=1; for(int i=1;i<len;i++) { if(s[i]==s[i-1]) cnt++; else { if(cnt%n==0) { if(st.insert(s[i-1]).second) v.push_back(s[i-1]); } else ump[s[i-1]]=-1; cnt=1; } } if(cnt%n==0) { if(st.insert(s[len-1-1]).second) v.push_back(s[len-1-1]); } else ump[s[len-1-1]]=-1; for(int i=0;i<v.size();i++) if(ump[v[i]]!=-1) putchar(v[i]); puts(""); for(int i=0;i<len;i++) { c=s[i]; if(ump[c]==-1) putchar(c); else { putchar(c); i+=n-1; } } puts(""); return 0; }