PAT (Advanced Level) Practice - 1112 Stucked Keyboard(20 分)

简介: PAT (Advanced Level) Practice - 1112 Stucked Keyboard(20 分)

题目链接:点击打开链接

题目大意:键盘某些键卡住了,按一次重复 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;
}
目录
相关文章
PAT (Advanced Level) Practice:1~3题
​ ✨欢迎您的订阅✨ PAT乙级专栏(更新完毕): 👉🏻【Basic Level】👈🏻 PAT甲级专栏(更新ing): 👉🏻【Advanced Level】👈🏻 ​
PAT (Advanced Level) Practice:1~3题
|
移动开发 C语言
PAT (Advanced Level) Practice 1042 Shuffling Machine (20 分)
PAT (Advanced Level) Practice 1042 Shuffling Machine (20 分)
67 0
PAT (Advanced Level) Practice - 1095 Cars on Campus(30 分)
PAT (Advanced Level) Practice - 1095 Cars on Campus(30 分)
111 0
PAT (Advanced Level) Practice - 1147 Heaps(30 分)
PAT (Advanced Level) Practice - 1147 Heaps(30 分)
96 0
PAT (Advanced Level) Practice - 1122 Hamiltonian Cycle(25 分)
PAT (Advanced Level) Practice - 1122 Hamiltonian Cycle(25 分)
95 0
PAT (Advanced Level) Practice - 1062 Talent and Virtue(25 分)
PAT (Advanced Level) Practice - 1062 Talent and Virtue(25 分)
122 0
PAT (Advanced Level) Practice - 1016 Phone Bills(25 分)
PAT (Advanced Level) Practice - 1016 Phone Bills(25 分)
97 0
|
索引
PAT (Advanced Level) Practice - 1056 Mice and Rice(25 分)
PAT (Advanced Level) Practice - 1056 Mice and Rice(25 分)
90 0
|
存储
PAT (Advanced Level) Practice - 1126 Eulerian Path(25 分)
PAT (Advanced Level) Practice - 1126 Eulerian Path(25 分)
113 0
PAT (Advanced Level) Practice - 1139 First Contact(30 分)
PAT (Advanced Level) Practice - 1139 First Contact(30 分)
93 0