栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

信息学奥赛一本通 2049:【例5.19】字符串判等

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

信息学奥赛一本通 2049:【例5.19】字符串判等

【题目链接】

ybt 2049:【例5.19】字符串判等

【题目考点】 1. 字符串 【解题思路】 解法1: 双指针

一个表示数组下标的变量,也可以叫做“指针”,它和C++指针在概念上是相通的。这里为两个字符数组分别设一个指针,两个指针分别在两个数组上遍历。

如果某指针指向空格,指针后移,指向下一个字符。如果两个指针指向的都是字母,那么看这两个字母是否“相同”,大小写不同的相同字母,也算相同的。如果相同,两指针同时后移,如果字母不同,说明两字符串不相等,程序结束。只要有一个指针没有遍历到最后,那么这个遍历比较的过程就要进行下去。如果两个字符串都遍历完了,程序还没有结束,说明两个字符串相等。 解法2:转化字符串,而后比较

把两个字符串都转化为只由小写字母组成的,没有空格的字符串,而后比较这两个字符串。

如果是字符数组,字符串的转化可以在一个字符数组上完成,设一个填充下标,每填充一个字符下标加1。如果是string类,那么可以设置新的string类对象表示转化后的字符串。 【题解代码】 解法1:双指针

#include
using namespace std;
int main()
{
    char s1[105], s2[105];
    int i = 0, j = 0, l1, l2;//i:s1的下标 j:s2的下标 也可以管i,j叫做指针 
    cin.getline(s1, 105);//读入带空格的字符串 
    cin.getline(s2, 105);
    l1 = strlen(s1);
    l2 = strlen(s2);
    while(i < l1 || j < l2)
    {//只要有一个数组没遍历完,就进行这一循环,直到都遍历完,或跳出。 
        if(s1[i] == ' ')
            i++;
        else if(s2[j] == ' ')
            j++;
        else
        {
            if(s1[i] == s2[j] || s1[i] == s2[j]+32 || s1[i]+32 == s2[j])
            {//如果两字母相同,或仅仅是大小写不同的相同字母 
                i++;
                j++; 
            }
            else
            {
                cout << "NO";
                return 0;
            } 
        }
    }
    cout << "YES";
    return 0;
}
解法2:转化字符串,而后比较

使用字符数组,在原字符数组上转化

#include
using namespace std;
int main()
{
    char s1[105], s2[105]; 
    int l1, l2, i, i1 , i2;//i1, i2:s1与s2转化为新字符串过程中填充字符串时用的下标 
    cin.getline(s1, 105);//读入带空格的字符串 
    cin.getline(s2, 105);
    l1 = strlen(s1);
    l2 = strlen(s2);
    for(i = 0, i1 = 0; i < l1; ++i)//把字符串s1转为只有小写字母无空格的字符串 
    {
        if(s1[i] >= 'a' && s1[i] <= 'z')
            s1[i1++] = s1[i];
        else if(s1[i] >= 'A' && s1[i] <= 'Z')
            s1[i1++] = s1[i] + 32;
    }
    s1[i1] = '';
    for(i = 0, i2 = 0; i < l2; ++i)//把字符串s2转为只有小写字母无空格的字符串 
    {
        if(s2[i] >= 'a' && s2[i] <= 'z')
            s2[i2++] = s2[i];
        else if(s2[i] >= 'A' && s2[i] <= 'Z')
            s2[i2++] = s2[i] + 32;
    }
    s2[i2] = '';
    cout << (strcmp(s1,s2) == 0 ? "YES" : "NO");
    return 0;
}

使用string类,转化为新的string类对象

#include
using namespace std;
string toNewStr(string s)//将s转化为只由小写字母组成的字符串 
{
    string r;
    for(int i = 0; i < s.length(); ++i)
    {
        if(s[i] >= 'a' && s[i] <= 'z')
            r.push_back(s[i]);
        else if(s[i] >= 'A' && s[i] <= 'Z')
            r.push_back(s[i] + 32);
    }
    return r;
} 
int main()
{
    string s1, s2, ns1, ns2;
    getline(cin, s1);//读入带空格的字符串 
    getline(cin, s2);
    ns1 = toNewStr(s1);//生成新字符串 
    ns2 = toNewStr(s2);
    cout << (ns1 == ns2 ? "YES" : "NO");
    return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/702871.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号