c语言(7.12)之AI助我学习2

笨笨的我写的:

#include <stdio.h>

int main()

{

printf("请输入小诗诗的排号:\n");

int rowa;

scanf_s("%d", &rowa);

printf("请输入小诗诗的坐号:\n");

int numa;

scanf_s("%d", &numa);

printf("请输入我的排号:\n");

int rowb;

scanf_s("%d", &rowb);

printf("请输入我的坐号:\n");

int numb;

scanf_s("%d", &numb);

if ((numb == numa+1||numa -1) && rowa == rowb)

{

printf("我会开心地看电影\n");

}

else

{

printf("我会开心地打游戏\n");

}

return 0;

}

AI的回答:

您的代码中 if 语句的条件部分存在逻辑错误。您想要检查的是 numanumb 是否相差1(无论是 numanumb 大1还是小1),但您的条件表达式 numb == numa+1||numa -1 并没有正确地表达这个逻辑。

numb == numa+1||numa -1 实际上被解析为 (numb == (numa+1)) || (numa - 1)。这里,(numa - 1) 是一个表达式,但它本身并不产生布尔值(尽管在C语言中,非零值被视为真,但这里它并没有被用作条件判断的一部分)。

您应该使用逻辑运算符来组合两个条件,分别检查 numa 是否等于 numb+1numb-1。这里是修改后的代码:

复制代码

c复制代码

|---|----------------------------------------------------------------------|
| | #include <stdio.h> |
| | |
| | int main() |
| | { |
| | printf("请输入小诗诗的排号:\n"); |
| | int rowa; |
| | scanf("%d", &rowa); // 注意:这里我改为了 scanf,因为 scanf_s 是 Microsoft 特有的 |
| | |
| | printf("请输入小诗诗的坐号:\n"); |
| | int numa; |
| | scanf("%d", &numa); |
| | |
| | printf("请输入我的排号:\n"); |
| | int rowb; |
| | scanf("%d", &rowb); |
| | |
| | printf("请输入我的坐号:\n"); |
| | int numb; |
| | scanf("%d", &numb); |
| | |
| | // 检查 numa 和 numb 是否相差 1,并且 rowa 和 rowb 相等 |
| | if ((numb == numa + 1 || numb == numa - 1) && rowa == rowb) |
| | { |
| | printf("我会开心地看电影\n"); |
| | } |
| | else |
| | { |
| | printf("我会开心地打游戏\n"); |
| | } |
| | |
| | return 0; |
| | } |

在这个修改后的版本中,我使用了 || 运算符来组合两个条件 numb == numa + 1numb == numa - 1,这两个条件通过 && 运算符与 rowa == rowb 相结合。这样,只有当这两个坐号相差1并且排号相同时,才会输出"我会开心地看电影"。否则,输出"我会开心地打游戏"。

另外,请注意我将 scanf_s 改为了 scanf,因为 scanf_s 是 Microsoft Visual C++ 特有的,用于提高安全性。如果您使用的是标准的 GCC 或 Clang 编译器,应该使用 scanf。如果您的环境确实需要 scanf_s(比如在使用 Visual Studio 时),并且您已经包含了正确的头文件(如 <stdio.s_s>,但请注意这通常是特定于 Visual Studio 的),那么您可以保留 scanf_s。不过,在大多数情况下,scanf 是更通用的选择。

相关推荐
嵌入式科普16 分钟前
十三、从0开始卷出一个新项目之瑞萨RZN2L串口DMA接收不定长
c语言·stm32·瑞萨·e2studio·rzn2l
_WndProc17 分钟前
C++ 日志输出
开发语言·c++·算法
biter008820 分钟前
opencv(15) OpenCV背景减除器(Background Subtractors)学习
人工智能·opencv·学习
努力学习编程的伍大侠30 分钟前
基础排序算法
数据结构·c++·算法
XiaoLeisj1 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Jasmine_llq1 小时前
《 火星人 》
算法·青少年编程·c#
Code哈哈笑1 小时前
【Java 学习】深度剖析Java多态:从向上转型到向下转型,解锁动态绑定的奥秘,让代码更优雅灵活
java·开发语言·学习
闻缺陷则喜何志丹1 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
Lenyiin2 小时前
01.02、判定是否互为字符重排
算法·leetcode