zl程序教程

您现在的位置是:首页 >  其他

当前栏目

试题 基础练习 字符串对比

基础试题 字符串 对比 练习
2023-09-11 14:20:19 时间

试题 基础练习 字符串对比(新手都能看懂)

资源限制

时间限制:1.0s 内存限制:512.0MB

问题描述

给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关系是以下4中情况之一:
  1:两个字符串长度不等。比如 Beijing 和 Hebei
  2:两个字符串不仅长度相等,而且相应位置上的字符完全一致(区分大小写),比如 Beijing 和 Beijing
  3:两个字符串长度相等,相应位置上的字符仅在不区分大小写的前提下才能达到完全一致(也就是说,它并不满足情况2)。比如 beijing 和 BEIjing
  4:两个字符串长度相等,但是即使是不区分大小写也不能使这两个字符串一致。比如 Beijing 和 Nanjing
  编程判断输入的两个字符串之间的关系属于这四类中的哪一类,给出所属的类的编号。
输入格式
  包括两行,每行都是一个字符串
输出格式
  仅有一个数字,表明这两个字符串的关系编号
样例输入
BEIjing
beiJing
样例输出
3

分析:

可以通过字符串数组进行一个个的比较,首先我们可以通过**length()**函数来知道是多大的数组。这样可以得到两个字符串的长度,就可以写出解决问题的代码了。

附上代码:(代码虽多但真的好懂)

#include<iostream>
using namespace std;

int main()
{
	int n=0;
	string a, b;
	cin >> a >> b;
   int string1(string a, string b);//调用函数
	int string2(string a, string b);
	int string3(string a, string b);
	int string4(string a, string b);
		//调用函数判断是几类
	if (string1(a, b))
		n=1;
	else if(string2(a, b))
		n=2;
	else if (string3(a, b))
		n=3;
	else if(string4(a, b))
		n=4;
	cout << n<<endl;
	return 0;
}
//第一类
int string1(string a, string b)
{
	if (a.length() != b.length())//长度不相等的时候输出为第一类
		return 1;
	else
		return 0;

}
//第二类
int string2(string a, string b)
{int m = 2;
	int l2=a.length() ,l1= b.length();
	if (l1 == l2)
	{
		for (int i = 0; i < l2; i++)
		{
			if (a[i] != b[i])
				m = 0;
		}
	}
	return m;
}
//第三类
int string3(string a, string b)
{
	int m = 3;
	int l2 = a.length(), l1 = b.length();
	if (l1 == l2)
	{//仅在不区分大小写的情况下,大小写相差32
		for (int i = 0; i < l2; i++)
		{
			if (m == 0) break;
			if ((a[i] + 32) == b[i] || (b[i] + 32) == a[i] || a[i] == b[i])
			{//存在相同的字母
				continue;
			}
			else
				m = 0;
		}

	}
	return m;
}//第四类:其他情况
int string4(string a, string b)
{
	return 4;
}

运行结果:

在这里插入图片描述