zoukankan      html  css  js  c++  java
  • 写一函数,实现两个字符串的比较。即自己写一个strcmp函数,函数原型为int strcmp(char * p1 ,char * p2); 设p1指向字符串s1, p2指向字符串s2。要求当s1=s2时,返回值为0;若s1≠s2,返回它们二者第1个不同字符的ASCII码差值(如"BOY"与"BAD"

    写一函数,实现两个字符串的比较。即自己写一个strcmp函数,函数原型为int strcmp(char * p1 ,char * p2); 设p1指向字符串s1, p2指向字符串s2。要求当s1=s2时,返回值为0;若s1≠s2,返回它们二者第1个不同字符的ASCII码差值(如"BOY"与"BAD" ,第2个字母不同,0与A之差为79- 65=14)。如果s1>s2,则输出正值;如果s1<s2,则输出负值。

    解题思路: 使用两个指针指向两个字符串首部,逐个往后进行比较,不相等的时候则将数据进行相减,作为返回值。

    答案:

    #include<stdio.h>
    #include<string.h>
    
    int mystrcmp(char *str1, char *str2)
    {
    	char *ptr1 = str1;
    	char *ptr2 = str2;
    	int res;
    	while (*ptr1 != '' && *ptr2 != '') {
    		if (*ptr1 != *ptr2) {
    			res = *ptr1 - *ptr2;
    			break;
    		}
    		ptr1++;
    		ptr2++;
    	}
    	if (*ptr1 == '' || *ptr2 == '') {//注意一个字符串到达结尾或者两个都到达结尾的情况
    		res = *ptr1 - *ptr2;
    	}
    	return res;
    }
    int main()
    {
    	char buf1[1024] = { 0 };
    	char buf2[1024] = { 0 };
    	while (1) {
    		printf("Please enter two strings:
    ");
    		gets_s(buf1, 1024);
    		gets_s(buf2, 1024);
    		printf("mystrcmp:%d", mystrcmp(buf1, buf2));
    		printf("
    ");
    	}
    	system("pause");
    	return 0;
    }
    
    

    写一函数,实现两个字符串的比较。即自己写一个strcmp函数,函数原型为int strcmp(char * p1 ,char * p2); 设p1指向字符串s1, p2指向字符串s2。要求当s1=s2时,返回值为0;若s1≠s2,返回它们二者第1个不同字符的ASCII码差值(如"BOY"与"BAD" ,第2个字母不同,0与A之差为79- 65=14)。如果s1>s2,则输出正值;如果s1<s2,则输出负值。

  • 相关阅读:
    面试中遇到的几道逻辑题目
    [转]计算机专业人工智能方向——研究生面试需知的十大问题
    new、delete、析构函数、自动类型转换
    第三章 传输层
    年后排序+ST表+ksm+矩阵ksm+斐波那契数列矩阵ksm+归并排序
    DP斜率优化
    DP现阶段优化
    平衡树(一)——二叉搜索树
    NOIP 2017-day2
    2017 NOIP2017 day 1
  • 原文地址:https://www.cnblogs.com/weiyidedaan/p/13292940.html
Copyright © 2011-2022 走看看