我想按字典顺序比较两个相同长度的字符串,其中包含拉丁字母。大写和小写字母被认为是相同的。

这是我的代码:

string in1,in2;
    getline(cin,in1);
    getline(cin,in2);
    int l=in1.length();

    for(int i=0;i<l;++i){
        in1[i]=tolower(in1[i]);
        in2[i]=tolower(in2[i]);
    }

    int sum1=0;
    int sum2=0;
    for(int i=0;i<l;++i){
        sum1=sum1 + int(in1[i]);
        sum2=sum2 + int(in2[i]);
    }
    if(sum1==sum2)
        cout<<"0"<<endl;
    if(sum1<sum2)
        cout<<"-1"<<endl;
    if(sum1>sum2)
        cout<<"1"<<endl;


但是,这在某些测试条件下会产生错误。

怎么了

最佳答案

您可以使用比较功能

int x = in1.compare(in2);
if(x == 0)
     cout<<"Both are Equal";
else if (x > 0)
    cout << in1 << " is greater than "<< in2 << endl;
else
    cout << in2 << " is greater than "<< in1 << endl;

09-15 11:46