鱼C论坛

 找回密码
 立即注册
查看: 2009|回复: 5

[已解决]关于实现strncmp函数的问题

[复制链接]
发表于 2022-11-1 21:58:43 | 显示全部楼层 |阅读模式
5鱼币
我没能理解小甲鱼最后的第28和第33行,如果说i++后又需要减一的话,那么为什么还要i++呢?

  1. #include <stdio.h>

  2. #define MAX 1024

  3. int main()
  4. {
  5.         char str1[MAX];
  6.         char str2[MAX];
  7.         int i = 0;
  8.         unsigned int n;

  9.         printf("请输入第一个字符串:");
  10.         while ((str1[i++] = getchar()) != '\n')
  11.                 ;

  12.         printf("请输入第二个字符串:");
  13.         i = 0;
  14.         while ((str2[i++] = getchar()) != '\n')
  15.                 ;

  16.         printf("请输入比较的字符数:");
  17.         scanf("%u", &n);

  18.         for (i = 0; i < n; i++)
  19.         {
  20.                 if (str1[i] - str2[i])
  21.                 {
  22.                         i++;
  23.                         break;
  24.                 }
  25.         }

  26.         printf("比较的结果是:%d\n", str1[i-1] - str2[i-1]);

  27.         return 0;
  28. }
复制代码
最佳答案
2022-11-1 21:58:44

i++ ,且-1是为了平衡 字符串相等和不相等时候i的值和数组下标的关系
i++是字符不相等时候才i++ 并跳出循环,但是 如果字符相等,for循环中会给i做++后再比下一个字符是否相等如果i<n不成立也是结束循环  不管字符是否相等 数组下标i的值都被多加了1 所以再减1。
如果i<n成立这时候还是继续比较下个字符直到i<n不成立。最后也是多做了一次i++
简言之,字符串相等时候会比字符串不等多做一次i++  ,所以要在不相等的判断中break前边做一次i++, 这用法很巧妙的把数组下标统一了
uTools_1667310953056.png

最佳答案

查看完整内容

i++ ,且-1是为了平衡 字符串相等和不相等时候i的值和数组下标的关系 i++是字符不相等时候才i++ 并跳出循环,但是 如果字符相等,for循环中会给i做++后再比下一个字符是否相等如果i
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-11-1 21:58:44 | 显示全部楼层    本楼为最佳答案   

i++ ,且-1是为了平衡 字符串相等和不相等时候i的值和数组下标的关系
i++是字符不相等时候才i++ 并跳出循环,但是 如果字符相等,for循环中会给i做++后再比下一个字符是否相等如果i<n不成立也是结束循环  不管字符是否相等 数组下标i的值都被多加了1 所以再减1。
如果i<n成立这时候还是继续比较下个字符直到i<n不成立。最后也是多做了一次i++
简言之,字符串相等时候会比字符串不等多做一次i++  ,所以要在不相等的判断中break前边做一次i++, 这用法很巧妙的把数组下标统一了

评分

参与人数 1鱼币 +5 收起 理由
1613551 + 5

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-11-1 22:01:29 | 显示全部楼层
如果不i++,且-1的话,就无法实现第三种输出结果了
uTools_1667311225382.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-11-1 22:02:39 | 显示全部楼层
why?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-11-2 00:44:44 From FishC Mobile | 显示全部楼层
其实 第28行不用 i++ 也可以,但是 第33行就不能 -1 了。如果 -1,那么就没有对齐不相同的字符了 。
假如 第一个字符串是 "ABCD",第二个字符串是"ABCd"。比较字符数为 4,那么循环 i = 3 的时候就触发  if (str1[i] - str2[i]) 这判断,str1[i] = 'D'(ASCII为 68), str2[i] = 'd'(ASCII为 100),然后str1[i](68) - str2[i](100) = -32。if (str1[i] - str2[i]) 就为真,不 i++ ,直接 break 退出循环。然后 第33行 直接 str1[i] - str2[i]。这样也能实现,但是 如果第33行 str1[i-1] - str2[i-1] 的话,那么 str1[i-1] = 'C', str2[i-1] = 'C',两个相减就为0了。
(个人观点 如有误欢迎大牛指正)

评分

参与人数 1鱼币 +5 收起 理由
1613551 + 5

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-11-2 07:19:54 | 显示全部楼层
不好意思,是我又脑抽风了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-2 14:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表