1613551 发表于 2022-11-1 21:58:43

关于实现strncmp函数的问题

我没能理解小甲鱼最后的第28和第33行,如果说i++后又需要减一的话,那么为什么还要i++呢?

#include <stdio.h>

#define MAX 1024

int main()
{
      char str1;
      char str2;
      int i = 0;
      unsigned int n;

      printf("请输入第一个字符串:");
      while ((str1 = getchar()) != '\n')
                ;

      printf("请输入第二个字符串:");
      i = 0;
      while ((str2 = getchar()) != '\n')
                ;

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

      for (i = 0; i < n; i++)
      {
                if (str1 - str2)
                {
                        i++;
                        break;
                }
      }

      printf("比较的结果是:%d\n", str1 - str2);

      return 0;
}

桃花飞舞 发表于 2022-11-1 21:58:44

1613551 发表于 2022-11-1 22:02
why?

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

1613551 发表于 2022-11-1 22:01:29

如果不i++,且-1的话,就无法实现第三种输出结果了

1613551 发表于 2022-11-1 22:02:39

why?{:10_254:}

3120781247 发表于 2022-11-2 00:44:44

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

1613551 发表于 2022-11-2 07:19:54

{:10_266:}不好意思,是我又脑抽风了
页: [1]
查看完整版本: 关于实现strncmp函数的问题