• PAT 1077 Kuchiguse [一般]


    1077 Kuchiguse (20 分)

    The Japanese language is notorious for its sentence ending particles. Personal preference of such particles can be considered as a reflection of the speaker's personality. Such a preference is called "Kuchiguse" and is often exaggerated artistically in Anime and Manga. For example, the artificial sentence ending particle "nyan~" is often used as a stereotype for characters with a cat-like personality:

    • Itai nyan~ (It hurts, nyan~)

    • Ninjin wa iyada nyan~ (I hate carrots, nyan~)

    Now given a few lines spoken by the same character, can you find her Kuchiguse?

    Input Specification:

    Each input file contains one test case. For each case, the first line is an integer N (2N100). Following are N file lines of 0~256 (inclusive) characters in length, each representing a character's spoken line. The spoken lines are case sensitive.

    Output Specification:

    For each test case, print in one line the kuchiguse of the character, i.e., the longest common suffix of all N lines. If there is no such suffix, write nai.

    Sample Input 1:

    3
    Itai nyan~
    Ninjin wa iyadanyan~
    uhhh nyan~
    

    Sample Output 1:

    nyan~
    

    Sample Input 2:

    3
    Itai!
    Ninjinnwaiyada T_T
    T_T
    

    Sample Output 2:

    nai

     题目大意:给出m个句子,判断所有句子的最长后缀。

    //有空格怎么办?那就不是一个character了。。。

    #include <iostream>
    #include <algorithm>
    #include<cstdio>
    #include <vector>
    #include<cstring>
    #include<string.h>
    #include<string>
    using namespace std;
    
    
    int main()
    {
        int n;
        cin>>n;
        string pe="",now;//那就以第一个作为标准,剩下的去和它作比较。
        int  j=258,k=258,mins=j;
        for(int i=0;i<n;i++){//如何读取一行,真的是不会。。。。
            getline(cin,now);
            if(pe==""){
                pe=now;continue;
            }
            for(j=pe.size()-1,k=now.size()-1;k>=0,j>=0;j--,k--){
                if(pe[j]!=now[k]){
                    break;
                }
            }
            if(j<mins){
                mins=j;
            }
        }
        if(mins==258){
            cout<<"nai";
        }else{
            for(int i=mins;i<pe.size();i++){
                cout<<pe[i];
            }
        }
    
    
        return 0;
    }
    View Code

    //本来是写成这个样子,根本就不行啊,不过整行读取字符串的函数写的是对的。

    根据柳神的修改了之后的,可以AC了

    #include <iostream>
    #include <algorithm>
    #include<cstdio>
    #include <vector>
    
    using namespace std;
    
    
    int main()
    {
        int n;
        cin>>n;
        string pe="",now,ans;//那就以第一个作为标准,剩下的去和它作比较。
        getline(cin,now);
        for(int i=0;i<n;i++){//如何读取一行,真的是不会。。。。
            getline(cin,now);
            reverse(now.begin(),now.end());
            if(i==0){
                ans=now;
            }else{
                int j=0;
                for(j=0;j<ans.size()&&j<now.size();j++){
                    if(ans[j]!=now[j])break;
                }
                ans=ans.substr(0,j);
            }
        }
        reverse(ans.begin(),ans.end());
        if(ans=="")
            cout<<"nai";
        else
            cout<<ans;
        return 0;
    }

    1.使用reverse进行倒转,因为是比较后缀,不太好比较,最后的答案需要再翻转过来。

    2.关于这个getline(cin,now)读取一行的问题,在输入了n之后,其实就有一个 被getline给读取进来了,所以这样就浪费了一个,需要单独加一个getline来消灭 才对!

    3.使用substr进行截取答案。 

  • 相关阅读:
    java的第八次作业
    软件工程第三次作业——关于软件质量保障初探
    java的第七次作业
    java的第六次作业
    20194688 自动生成四则运算题第一版报告
    软件工程第一次作业
    vertical-align
    行高(line-height)
    文本对齐方式(text-align)
    文字样式属性
  • 原文地址:https://www.cnblogs.com/BlueBlueSea/p/9915435.html
Copyright © 2020-2023  润新知