题解 | 找位置

#include <bits/stdc++.h>
using namespace std;

typedef struct cop{
    char a;
    int count;
}cp;

int find(cp arr[],int n,char b){
    for(int i=0;i<n;i++){
        if(arr[i].a==b){
            return i;
            break;
        }
    }
    return -1;
}

int main(){
    string s;
    cin>>s;
    cp arr[s.size()];
    int n=0;
    for(char c:s){
        if(find(arr,n,c)!=-1){
            arr[find(arr,n,c)].count++;
        }
        else{
            arr[n].a=c;
            arr[n].count=1;
            n++;
        }
    }
    for(int i=0;i<n;i++){
        if(arr[i].count!=1){
            for(int j=0;j<s.size();j++){
                if(s[j]==arr[i].a){
                    arr[i].count--;
                    if(arr[i].count!=0){
                        printf("%c:%d,",s[j],j);
                    }else{
                        printf("%c:%d",s[j],j);
                    }
                    
                }
            }
            printf("\n");
        }
    }
}

本题的难度在于格式化输出,根据要求,我们需要找出来出现次数大于1的所有字母,按照出现顺序依次输出其出现的位置,这样的话,只需要把这些内容存起来,用一个结构体存内容和数量,然后遍历即可,最后在输出的时候,由于尾部不同,所以需要在输出的时候对count进行减一

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 11:30
仁者伍敌:kpi都懒得刷了属于是
点赞 评论 收藏
分享
叶扰云倾:进度更新,现在阿里云面完3面了,感觉3面答得还行,基本都答上了,自己熟悉的地方也说的比较细致,但感觉面试官有点心不在焉不知道是不是不想要我了,求阿里收留,我直接秒到岗当阿里孝子,学校那边的房子都退租了,下学期都不回学校,全职猛猛实习半年。这种条件还不诱人吗难道 然后现在约到了字节的一面和淘天的复活赛,外加猿辅导。华为笔试完没动静。 美团那边之前投了个base广州的,把我流程卡麻了,应该是不怎么招人,我直接简历挂了,现在进了一个正常的后端流程,还在筛选,不知道还有没有hc。
点赞 评论 收藏
分享
风中翠竹:真的真的真的没有kpi。。。面试官是没有任何kpi的,捞是真的想试试看这个行不行,碰碰运气,或者是面试官比较闲现在,没事捞个人看看。kpi算HR那边,但是只有你入职了,kpi才作数,面试是没有的。
双非有机会进大厂吗
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-03 18:13
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务