• Codeforces Round #293 (Div. 2) A. Vitaly and Strings


    A. Vitaly and Strings
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Vitaly is a diligent student who never missed a lesson in his five years of studying in the university. He always does his homework on time and passes his exams in time.

    During the last lesson the teacher has provided two strings s and t to Vitaly. The strings have the same length, they consist of lowercase English letters, string s is lexicographically smaller than string t. Vitaly wondered if there is such string that is lexicographically larger than string s and at the same is lexicographically smaller than string t. This string should also consist of lowercase English letters and have the length equal to the lengths of strings s and t.

    Let's help Vitaly solve this easy problem!

    Input

    The first line contains string s (1 ≤ |s| ≤ 100), consisting of lowercase English letters. Here, |s| denotes the length of the string.

    The second line contains string t (|t| = |s|), consisting of lowercase English letters.

    It is guaranteed that the lengths of strings s and t are the same and string s is lexicographically less than string t.

    Output

    If the string that meets the given requirements doesn't exist, print a single string "No such string" (without the quotes).

    If such string exists, print it. If there are multiple valid strings, you may print any of them.

    Sample test(s)
    Input
    a
    c
    Output
    b
    Input
    aaa
    zzz
    Output
    kkk
    Input
    abcdefg
    abcdefh
    Output
    No such string
    Note

    String s = s1s2... sn is said to be lexicographically smaller than t = t1t2... tn, if there exists such i, that s1 = t1, s2 = t2, ... si - 1 = ti - 1, si < ti.

    题意:给你两个字符串a,b,然后让你输出一个字符串,这个字符串c要求满足 a<c<b

    坑点在于z++之后,就不是字母了,这点需要判断一下就是了

    string a;
    string b;
    string c;
    int main()
    {
            cin>>a>>b;
            c=a;
            for(int i=a.size()-1;i>=0;i--)
            {
                    if(c[i]=='z')
                            c[i]-=25;
                    else
                    {
                            c[i]++;
                            break;
                    }
            }
            int flag=0;
            for(int i=0;i<a.size();i++)
            {
                    if(c[i]<b[i])
                    {
                            flag=1;
                            break;
                    }
                    if(c[i]>b[i])
                    {
                            flag=0;
                            break;
                    }
            }
            if(flag==0)
                    cout<<"No such string"<<endl;
            else
                    cout<<c<<endl;
    }
  • 相关阅读:
    chrome/edge 自签名证书造成浏览器无法访问
    linux 下 取进程占用内存(MEM)最高的前10个进程
    总结记录一下我对YZ数据中台指标相关平台的理解感悟与思考
    史上最全之微信群发拼手气红包测试用例
    vue使用filterBy,orderBy实现搜索筛选功能
    前端处理防抖和节流
    箭头函数()=>{}与function的区别
    html不用任何控件上传文件
    Java必备知识--线程池
    Java必备知识--日志框架
  • 原文地址:https://www.cnblogs.com/qscqesze/p/4305377.html
Copyright © 2020-2023  润新知