怎样用c++编写比较两个字符串的大小(用指针)

任意输入两个字符串,怎样用c++编写比较两个字符串的大小(用指针)题目要求:不能用strcmp... 任意输入两个字符串,
怎样用c++编写比较两个字符串的大小(用指针)
题目要求:不能用strcmp
展开
 我来答
百度网友8637197e4
推荐于2018-05-15 · 超过15用户采纳过TA的回答
知道答主
回答量:78
采纳率:0%
帮助的人:48.9万
展开全部
#include <iostream>
using namespace std;

int cmp(char *s, char *p);

int main()
{
char m[20],n[20];
cin>>m>>n;
int i = cmp(m,n);
if (i == 0)
cout <<"两者相等"<<endl;
if (i == 1)
cout << "前者大于后者"<< endl;
if (i == -1)
cout << "前者小于后者" << endl;
return 0;
}

int cmp(char *s, char *p)
{
while (*s&&*p)
{
if (*s>*p)
return 1;
else if (*s < *p)
return -1;
else
{
if (*(s+1) == '\0' && *(p+1) != '\0')
return -1;
else if (*(s+1) != '\0' && *(p+1) == '\0')
return 1;
else if (*(s+1) == '\0'&&*(p+1)=='\0')
return 0;
else
{
s++,p++;
continue;
}
}
}
}
FrankHB1989
2010-05-15 · TA获得超过4.2万个赞
知道大有可为答主
回答量:4569
采纳率:100%
帮助的人:3050万
展开全部
看来就是自己实现一个strcmp了...以下应该是最简单的写法了...
//非模板版本:
int mystrcmp(const char* s1, const char* s2)
{
while(*s1 && *s2 && *s1 == *s2)
{
++s1;
++s2;
}
return *s1 - *s2;
}
//简单模板版本,适合char、wchar_t之类的等宽C风格字符串:
template<typename _CharT>
int mystrcmp(const _CharT* s1, const _CharT* s2)
{
while(*s1 && *s2 && *s1 == *s2)
{
++s1;
++s2;
}
return *s1 - *s2;
}
====
[原创回答团]

参考资料: 原创

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
我是IT农民工
2010-05-16
知道答主
回答量:32
采纳率:0%
帮助的人:16.1万
展开全部
#include<stdio.h>
strcmp (char *p,char *q)
{
while(*p==*q)
{
if(*p==0) return(0);
p++;q++;
}
return(*p-*q);
}
main()
{
char a[21],b[21];
printf("请输入字符串a:");
gets(a);
printf("请输入字符串b:");
gets(b);
printf("\n strcmp(a,b)=%d \n",strcmp(a,b));
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友8438d0f
2010-05-15
知道答主
回答量:2
采纳率:0%
帮助的人:0
展开全部
可以用strcmp();函数来做比较 使用是要包含头文件string.h如果已经包含了iostream就不需要包含string.h了
用法为strcmp(string1,string2);这个函数有返回值的 如果返回的是1代表前者大 -1就是后者大 一样大是0
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
令琬宝和裕
2019-11-02 · TA获得超过3652个赞
知道大有可为答主
回答量:3109
采纳率:34%
帮助的人:220万
展开全部
#include
using
namespace
std;
int
cmp(char
*s,
char
*p);
int
main()
{
char
m[20],n[20];
cin>>m>>n;
int
i
=
cmp(m,n);
if
(i
==
0)
cout
<<"两者相等"<
if
(i
==
1)
cout
<<
"前者大于后者"<<
endl;
if
(i
==
-1)
cout
<<
"前者小于后者"
<<
endl;
return
0;
}
int
cmp(char
*s,
char
*p)
{
while
(*s&&*p)
{
if
(*s>*p)
return
1;
else
if
(*s
<
*p)
return
-1;
else
{
if
(*(s+1)
==
'\0'
&&
*(p+1)
!=
'\0')
return
-1;
else
if
(*(s+1)
!=
'\0'
&&
*(p+1)
==
'\0')
return
1;
else
if
(*(s+1)
==
'\0'&&*(p+1)=='\0')
return
0;
else
{
s++,p++;
continue;
}
}
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(6)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式