Gordon1 发表于 2024-2-12 21:55:16

FishC 发表于 2024-2-12 21:45
当然可以,下面是使用程序格式的修复后的代码:




为什么没有指令3和4的代码,而且指令2的代码是指令3的

FishC 发表于 2024-2-12 21:55:55

Gordon1 发表于 2024-02-12 21:55
为什么没有指令3和4的代码,而且指令2的代码是指令3的

非常抱歉,我之前的回答有误。是的,指令2的代码应该是指令3的。让我们来修复这个问题并添加指令3和指令4的代码。

#include <stdio.h>
#include <stdlib.h>

int main() {
    int count1 = 0, count2 = 0;
    int M, N;
    int *matrix = NULL;
    int instruction;

    printf("=============================\n");
    printf("* 欢迎使用该程序,指令如下:*\n");
    printf("* 1. 生成一个 M*N 的矩阵   *\n");
    printf("* 2. 初始化矩阵            *\n");
    printf("* 3. 给矩阵中某个元素赋值    *\n");
    printf("* 4. 读取矩阵中某个元素      *\n");
    printf("* 5. 打印整个矩阵            *\n");
    printf("* 6. 结束程序                *\n");
    printf("=============================\n\n");

    do {
      printf("请输入指令:");
      scanf("%d", &instruction);
      count1++;

      if (instruction == 1) { // 指令1 - 生成矩阵
            count2++;
            if (count2 > 1) {
                printf("矩阵已存在,是否需要重新创建(Y/N)->");
                char choice;
                scanf(" %c", &choice);

                if (choice == 'Y' || choice == 'y') {
                  free(matrix);
                  count2 = 0;
                } else {
                  continue;
                }
            }

            printf("请输入矩阵的行数和列数(M N):");
            scanf("%d%d", &M, &N);
            matrix = (int *)malloc(M * N * sizeof(int));

            printf("成功生成 %d*%d 的矩阵!\n\n", M, N);
      } else if (instruction == 2) { // 指令2 - 初始化矩阵
            if (count2 == 0) {
                printf("矩阵未创建,请先生成一个矩阵!\n\n");
                continue;
            }

            int value;
            printf("请输入要用来初始化矩阵的值:");
            scanf("%d", &value);

            for (int i = 0; i < M * N; i++) {
                matrix = value;
            }

            printf("矩阵初始化成功!\n\n");
      } else if (instruction == 3) { // 指令3 - 给矩阵中某个元素赋值
            if (count2 == 0) {
                printf("矩阵未创建,请先生成一个矩阵!\n\n");
                continue;
            }

            int row, col, value;
            printf("请输入要赋值的元素的行和列索引(行 列):");
            scanf("%d%d", &row, &col);

            if (row < 0 || row >= M || col < 0 || col >= N) {
                printf("输入的行和列索引超出矩阵范围,请重新输入!\n\n");
                continue;
            }

            printf("请输入要赋的值:");
            scanf("%d", &value);

            matrix = value;
            printf("成功将矩阵中第 %d 行第 %d 列的元素赋值为 %d!\n\n", row, col, value);
      } else if (instruction == 4) { // 指令4 - 读取矩阵中某个元素
            if (count2 == 0) {
                printf("矩阵未创建,请先生成一个矩阵!\n\n");
                continue;
            }

            int row, col;
            printf("请输入要读取的元素的行和列索引(行 列):");
            scanf("%d%d", &row, &col);

            if (row < 0 || row >= M || col < 0 || col >= N) {
                printf("输入的行和列索引超出矩阵范围,请重新输入!\n\n");
                continue;
            }

            int value = matrix;
            printf("矩阵中第 %d 行第 %d 列的元素的值为:%d\n\n", row, col, value);
      } else if (instruction == 5) { // 指令5 - 打印整个矩阵
            if (count2 == 0) {
                printf("矩阵未创建,请先生成一个矩阵!\n\n");
                continue;
            }

            for (int i = 0; i < M; i++) {
                for (int j = 0; j < N; j++) {
                  printf("%d ", matrix);
                }
                printf("\n");
            }

            printf("\n");
      } else if (instruction == 6) { // 指令6 - 结束程序
            free(matrix);
            printf("程序已结束,欢迎下次使用!\n");
            break;
      } else {
            printf("输入的指令无效,请重新输入!\n\n");
      }
    } while (1);

    return 0;
}

这个修复后的代码中,我们添加了指令3和指令4的代码,可以分别用来给矩阵中某个元素赋值和读取矩阵中某个元素的值。希望这次的代码更符合您的期望,如果还有其他问题,请随时提问。

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

Gordon1 发表于 2024-2-12 22:01:20

FishC 发表于 2024-2-12 21:55
非常抱歉,我之前的回答有误。是的,指令2的代码应该是指令3的。让我们来修复这个问题并添加指令3和指 ...

能告诉我为什么我之前的程序会自己结束吗

FishC 发表于 2024-2-12 22:01:32

Gordon1 发表于 2024-02-12 22:01
能告诉我为什么我之前的程序会自己结束吗

在您之前的程序中,没有正确处理结束程序的指令。在指令6中,您没有使用`break;`来跳出循环,因此程序会继续执行下去,导致无法正确退出。这是导致程序自动结束的原因。

修复这个问题非常简单,只需在指令6的分支中添加`break;`语句即可。这样程序就能正确退出循环并结束了。以下是修复后的代码片段:

else if (instruction == 6) { // 指令6 - 结束程序
    free(matrix);
    printf("程序已结束,欢迎下次使用!\n");
    break; // 添加break来跳出循环
}

希望这次的解释能够帮助您理解问题所在。如果还有其他问题,请随时提问。

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

Gordon1 发表于 2024-2-12 22:02:55

FishC 发表于 2024-2-12 22:01
在您之前的程序中,没有正确处理结束程序的指令。在指令6中,您没有使用`break;`来跳出循环,因此程序 ...

我的意思是为什么之前输入完3或4或5之后不会继续让我输入指令,而是结束程序

FishC 发表于 2024-2-12 22:03:10

Gordon1 发表于 2024-02-12 22:02
我的意思是为什么之前输入完3或4或5之后不会继续让我 ...

非常抱歉,我误解了您的问题。在您的程序中,确实存在一个问题导致输入完3、4或5后程序会结束。问题出现在循环的外层,当用户输入指令为3、4或5时,您没有将程序回到循环的开头,而是直接跳到了程序的结束部分。这就导致了程序无法再次进入到用户输入指令的阶段。

要解决这个问题,您需要将用户输入指令的部分放入一个内层循环中,然后使用 `break` 语句跳出内层循环,继续让用户输入指令。

下面是修复后的代码片段示例:

do {
    printf("请输入指令:");
    scanf("%d", &yonghu);

    // ... 其他指令处理逻辑

    if (yonghu == 6) { // 指令6 - 结束程序
      free(array);
      printf("程序已结束,欢迎下次使用!\n");
      break;
    }
} while (1);

在这个修复后的代码中,我们使用了一个 `do-while` 循环来持续地等待用户输入指令。当用户输入指令为6时,我们释放内存、打印结束信息并使用 `break` 跳出整个循环,结束程序。

希望这次能够解决您的问题。如果还有其他疑问,请随时提问。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: 1 [2]
查看完整版本: 矩阵小程序