牛客--2019快手--字符串归一化

题目描述:
通过键盘输入一串小写字母(a~z)组成的字符串。
请编写一个字符串归一化程序,统计字符串中相同字符出现的次数,并按字典序输出字符及其出现次数。
例如字符串"babcc"归一化后为"a1b2c2"
输入描述:
每个测试用例每行为一个字符串,以’\n’结尾,例如cccddecca
输出描述:
输出压缩后的字符串ac5d2e
输入:
dabcab
输出:
a2b2c1d1
题意:
题目描述
题解
暴力,记录了直接输出
代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;

const int maxn = 100000 + 5;
char s[maxn];
int vis[30];

int main(){
    while(scanf("%s",s)!=EOF){
        memset(vis,0,sizeof(vis));
        int l = strlen(s);
        for(int i = 0; i < l; i ++){
            int t = s[i] - 'a';
            vis[t] ++;
        }
        for(int i = 0; i < 26; i ++){
            if(vis[i] != 0){
                printf("%c%d",'a' + i,vis[i]);
            }
        }
        printf("\n");
    }
    return 0;
}

发布了228 篇原创文章 · 获赞 1 · 访问量 13万+

猜你喜欢

转载自blog.csdn.net/Ypopstar/article/details/105124222