美文网首页
CodeFoeces-960A

CodeFoeces-960A

作者: ss5smi | 来源:发表于2018-04-11 21:57 被阅读0次

    题目

    原题链接:A. Check the string

    题意

    给出仅由a、b和c组成的字符串,每个字母出现最少一次,且按照顺序集中出现,c的数量等于a或b的数量。问是否满足要求。

    代码

    #include<bits/stdc++.h>
    using namespace std;
    int main() {
        string s;
        cin>>s;
        int a=0,b=0,c=0,i,beg,end;
        for(i=0; i<s.length(); i++) {
            if(s[i]=='b') {
                beg=i;
                break;
            }
        }
        for(i=s.length(); i>=0; i--) {
            if(s[i]=='b') {
                end=i;
                break;
            }
        }
        for(i=0; i<beg; i++) {
            if(s[i]!='a') {
                printf("NO\n");
                return 0;
            }
        }
        for(i=beg; i<=end; i++) {
            if(s[i]!='b') {
                printf("NO\n");
                return 0;
            }
        }
        for(i=end+1; i<s.length(); i++) {
            if(s[i]!='c') {
                printf("NO\n");
                return 0;
            }
        }
        for(i=0; i<s.length(); i++) {
            if(s[i]!='a') break;
            a++;
        }
        for(i; i<s.length(); i++) {
            if(s[i]!='b') break;
            b++;
        }
        for(i; i<s.length(); i++) {
            if(s[i]!='c') break;
            c++;
        }
        if((a==c || b==c) && a && b && c) printf("YES\n");
        else printf("NO\n");
        return 0;
    }
    

    相关文章

      网友评论

          本文标题:CodeFoeces-960A

          本文链接:https://www.haomeiwen.com/subject/pxynhftx.html