#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include<string.h> #include<ctype.h> int main() { int n; int a[6000] = { 0 }; scanf("%d", &n); for (int sum = n, num = 2; sum > 3;) { for (int i = 0, j = 1; i < n; i++) { if (a[i] == 0) if (j == num) { a[i] = -1; j = 1; sum--; } else { j++; } } if (num == 2) { num == 3; } else num == 2; } for (int i = 0, b = 0; i < n; i++) { if (a[i] == 0) { if (b == 0) { printf("%d", i + 1); b = 1; } else printf(" %d", i + 1); } } return 0; }这个代码啥问题
时间: 2023-12-02 16:04:13 浏览: 90
这段代码有几个问题:
1. 缺少头文件 `stdlib.h`,应该加上 `#include<stdlib.h>`。
2. `num == 3` 和 `num == 2` 都应该改为 `num = 3` 和 `num = 2`,否则语法错误。
3. 在第 21 行,应该将 `num` 赋值为 3,而不是赋值为 2。
4. 在第 26 行,应该将 `num` 赋值为 2,而不是赋值为 3。
5. 在第 28 行,应该使用赋值运算符 `=`,而不是相等运算符 `==`。
6. 在第 35 行,应该将 `%d` 和后面的参数改为 `"%d\n"`,使输出的每个数字都单独占一行。
7. 在第 35 行,应该将 `i + 1` 改为 `i`,因为数组下标从 0 开始。
8. 在第 17 行,应该判断 `sum` 是否大于 2,因为当 `n` 等于 2 或 3 时,不需要进行循环。
9. 在第 32 行,如果 `a[i]` 的值已经为 -1,则不需要再进行判断。
10. 在第 32 行,应该在判断 `a[i]` 是否等于 0 的条件后面加上逻辑运算符 `&&`,并判断 `sum` 是否大于 2,否则会出现数组越界的错误。
下面是修改后的代码:
```
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
int main()
{
int n;
int a[6000] = { 0 };
scanf("%d", &n);
for (int sum = n, num = 2; sum > 2;)
{
for (int i = 0, j = 1; i < n && sum > 2; i++)
{
if (a[i] == 0 && j == num)
{
a[i] = -1;
j = 1;
sum--;
}
else if (a[i] == 0)
{
j++;
}
}
if (num == 2)
{
num = 3;
}
else
{
num = 2;
}
}
for (int i = 0, b = 0; i < n; i++)
{
if (a[i] == 0)
{
if (b == 0)
{
printf("%d\n", i);
b = 1;
}
else
{
printf("%d\n", i);
}
}
}
return 0;
}
```
阅读全文