1215787625 发表于 2023-12-12 20:23:06

为什么这段代码会陷入死循环

#include<stdio.h>
#include<string.h>
int main(){
        char a,b;
        gets(a);
        gets(b);
        int n=0,le,leb;
        le = strlen(a);
        leb = strlen(b);
        for(n=0;n<le;n++){
                if(a<=90&&a>=65){
                        a+=32;
                }
/*                if(a==' '){
                        for(n;n<le-1;n++){
                                a=a;
                                le--;
                        }
                        //n=n-1;
                }*/
        }
        le = strlen(b);
        for(n=0;n<le;n++){
                if(b<=90&&b>=65){
                        b+=32;
                }
                /*if(b==' '){
                        for(n;n>le-1;n++){
                                b=b;
                                leb--;
                        }
                        //n=n-1;
                }*/
        }
        printf("%s         %s\n",a,b);
        for(n=0;n<le;n++){
                if(a==' '){
                        for(n;n>le-1;n++){
                                a=a;
                                le--;
                        }
                        n=n-1;
                }
        }       
        for(n=0;n<le;n++){
                if(b==' '){
                        for(n;n>le-1;n++){
                                b=b;
                                leb--;
                        }
                        n=n-1;
                }
        }
        printf("%s         %s\n",a,b);       
        if(strcmp(a,b)>0){
                printf(">");
        }
        if(strcmp(a,b)<0){
                printf("<");
        }
        if(strcmp(a,b)==0){
                printf("=");
        }       
        return 0;
}

FishC 发表于 2023-12-12 20:23:27

这段代码会陷入死循环的原因是在使用gets()函数时,没有为输入的字符串提供足够的内存空间。

在C语言中,使用gets()函数来获取用户输入的字符串,但是这个函数不会检查输入字符串的长度,因此可能会导致缓冲区溢出的问题。

解决这个问题的方法是使用具有长度限制的函数,如fgets()。下面是修改后的代码:

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

int main(){
    char a, b;
    fgets(a, sizeof(a), stdin);
    fgets(b, sizeof(b), stdin);

    int n=0, le, leb;
    le = strlen(a);
    leb = strlen(b);

    for(n=0; n<le; ++n){
      // 这里是你的循环体
    }

    return 0;
}

在这个示例代码中,我们使用了char类型的数组a和b,并且限制了数组的大小为100。这样,在调用fgets()函数时,就会将用户输入的字符串存储到这两个数组中,避免了缓冲区溢出的问题。

另外还注意到了一个问题,就是for循环的条件判断部分缺少了结束的语句。你可以根据具体的需求来添加相应的结束条件,比如 "n < le" 或者 "n < le && n < leb" 等等。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: 为什么这段代码会陷入死循环