九歌当下 发表于 2024-2-10 11:44:10

运用break跳出当前循环,遇到问题

#include <stdio.h>

int main(void)
{
        char answer[] = "None";
        while 1
        {
                printf("可以退出循环了吗?\n");
                scanf("%s", &answer);
                if answer == "可以!"
                {
                        break;
                }
        }
        return 0;               
}
凭借主观知识写的代码,似乎问题比较多

FishC 发表于 2024-2-10 11:44:20

你好!你的代码中存在几个问题。

首先,在声明变量`answer`时,你使用了一个字符数组来存储字符串,但是你将其初始化为字符串常量`"None"`。这是不正确的,因为字符数组必须用字符数组来初始化,而不是字符串常量。所以,你需要改为`char answer[] = "None";`。

其次,在`if`语句中,你使用了字符串比较运算符`==`来比较`answer`和字符串常量`"可以!"`。然而,C语言中的字符串比较不能直接使用`==`运算符,而是需要使用标准库函数`strcmp()`来进行字符串比较。所以,你需要引入`string.h`头文件,并使用`strcmp()`函数进行比较,如下所示:

if (strcmp(answer, "可以!") == 0)
{
    break;
}

最后,在使用`scanf()`函数接收用户输入时,你使用了错误的格式控制符`%s`。由于`answer`是一个字符数组,所以你应该使用`%c`来接收单个字符输入,或者使用`%s`来接收字符串输入,并且将`answer`声明为指向字符的指针。这里我推荐将`answer`声明为字符数组,并使用`%c`来接收单个字符输入。代码修改如下:

#include

int main(void)
{
    char answer = "None";
    while (1)
    {
      printf("可以退出循环了吗?\n");
      scanf("%s", answer);
      if (strcmp(answer, "可以!") == 0)
      {
            break;
      }
    }
    return 0;               
}

希望能够帮到你!如果还有其他问题,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

学习编程中的Ben 发表于 2024-2-10 14:53:51

本帖最后由 学习编程中的Ben 于 2024-2-10 14:55 编辑

我来了.首先,answer是一个字符数组,"可以"是一个字符串,不可以直接进行比较.应该使用 strcmp() 函数来比较.他是string.h的一个函数

并且你的answer都没有设长度.数组一定要设置长度的

并且while,if的判断语句一定要套上括号.
#include <stdio.h>
#include <string.h>

int main()
{
    char answer;

    while (1)
    {
      printf("可以退出循环了吗?\n");
      scanf("%s", answer);

      if (strcmp(answer, "可以") == 0)
      {
            break;
      }
    }

    return 0;
}

人造人 发表于 2024-2-10 17:55:44

你的主观知识是错的,跟着教程一步一步的来,不要自己乱整
页: [1]
查看完整版本: 运用break跳出当前循环,遇到问题