NOI
/
1.7编程基础之字符串
16:忽略大小写的字符串比较
总时间限制:
1000ms
内存限制:
65536kB
描述
一般我们用strcmp可比较两个字符串的大小,比较方法为对两个字符串从前往后逐个字符相比较(按ASCII码值大小比较),直到出现不同的字符或遇到'\0'为止。如果全部字符都相同,则认为相同;如果出现不相同的字符,则以第一个不相同的字符的比较结果为准(注意:如果某个字符串遇到'\0'而另一个字符串还未遇到'\0',则前者小于后者)。但在有些时候,我们比较字符串的大小时,希望忽略字母的大小,例如"Hello"和"hello"在忽略字母大小写时是相等的。请写一个程序,实现对两个字符串进行忽略字母大小写的大小比较。
输入
输入为两行,每行一个字符串,共两个字符串。(每个字符串长度都小于80)
输出
如果第一个字符串比第二个字符串小,输出一个字符"<";
如果第一个字符串比第二个字符串大,输出一个字符">";
如果两个字符串相等,输出一个字符"="。
样例输入
Hello, how are you? hello, How are you?
样例输出
=
来源
计算概论05
全局题号
8174
添加于
2015-04-21
提交次数
53184
尝试人数
20613
通过人数
18838
你的提交记录
# | 结果 | 时间 |
1 | Accepted | 2022-10-16 |
- ©2002-2022 POJ 京ICP备20010980号-1
0.先比ASCII码再比长度。
1.先把大写都改为小写。
2.再转换成ASCII码来比较
3.如果“分不出胜负”,就比长度。
4.最后输出>、<或=。
废话不多说,上代码!!!!!!!!(1300字)
#include<bits/stdc++.h>
using namespace std;
int main()//有亿点点长
{
string a,b;
getline(cin,a);
getline(cin,b);
int len1=a.length();//获取长度(咋又是你???!!!)
int len2=b.length();
int sum;//长度3(以后会用)
for(int i=0;i<=len1-1;i++)
{
if(a[i]>='A'&&a[i]<='Z')//是否是大写
{
a[i]=a[i]+32;//是则转为小写
}
}
for(int i=0;i<=len2-1;i++)
{
if(b[i]>='A'&&b[i]<='Z')
{
b[i]=b[i]+32;
}
}
if(len1>len2)
{
sum=len2;//提取长度
}
else
{
sum=len1;
}
for(int i=0;i<=sum-1;i++)
{
if(a[i]==b[i])
{
continue;//如果字符一样,跳过,下一个
}
else if(a[i]>b[i])
{
cout<<">";//直到比出大小
return 0;
}
else
{
cout<<"<"
return 0;
}
}
if(len1==len2)
{
cout<<"=";//比长度
}
else if(len1>len2)
{
cout<<">";
}
else
{
cout<<"<";
}
return 0;
}