1215787625 发表于 2023-11-22 19:57:26

为什么这个代码无法读入max与min的值

#include <stdio.h>
#include <string.h>
int main(void)
{
    char max,min,a={0},b={0};
    gets(a);
    gets(b);
    int c=0,n,m,min1;
    n = n+1;
    for(c=0;b=='\0';c++){
    n=(int)b;
    m = (int)b;
        if(n-m>0){
      max = b;
    }
    else{
    max = b;
    }
    }
    printf("%c\n\n",max);
    for(c=0;a=='\0';c++){
    n = (int)a;
    m = (int)a;
        if(n-m>0){
      min = a;
      min1 = c;
    }
    else{
    min = a;
    min1 = c;
    }
    }
    printf("%c",max);
   printf("%d",min);
    for(c=0;c<min1;c++){
      printf("%c",a);
    }
    printf("%c",max);
    for(c;c<strlen(a);c++){
      printf("%c",a);
    }
    return 0;
}

isdkz 发表于 2023-11-22 19:57:48

这段代码存在一些问题,导致无法正确读入max和min的值。以下是修复后的代码:

#include <stdio.h>
#include <string.h>

int main(void)
{
    char max, min, a = {0}, b = {0};
    gets(a);
    gets(b);
    int c = 0, n, m, min1 = 0; // 初始化min1为0
    n = strlen(b); // 使用strlen函数获取字符串长度
    for (c = 0; c < n - 1; c++) // 修正循环条件
    {
      n = (int)b;
      m = (int)b;
      if (n - m > 0)
      {
            max = b;
      }
      else
      {
            max = b;
      }
    }
    printf("%c\n\n", max);
    n = strlen(a); // 使用strlen函数获取字符串长度
    for (c = 0; c < n - 1; c++) // 修正循环条件
    {
      n = (int)a;
      m = (int)a;
      if (n - m > 0)
      {
            min = a;
            min1 = c;
      }
      else
      {
            min = a;
            min1 = c;
      }
    }
    printf("%c", max);
    printf("%c", min);
    for (c = 0; c < min1; c++)
    {
      printf("%c", a);
    }
    printf("%c", max);
    for (c = min1; c < strlen(a); c++) // 修正循环起始位置
    {
      printf("%c", a);
    }
    return 0;
}


这段代码修复了以下问题:
1. 修正了循环条件,确保正确遍历字符串。
2. 使用 strlen 函数获取字符串长度,避免未初始化变量。
3. 修正了min1的赋值位置,确保正确记录最小值的索引。

请注意,上述代码仅仅是修复了原始代码中的错误,但仍然存在一些潜在的问题,比如没有对输入进行有效性检查,使用了不安全的 gets 函数等。在实际的程序中,应该使用更安全和健壮的方法来实现相同的功能。
页: [1]
查看完整版本: 为什么这个代码无法读入max与min的值