鱼C论坛

 找回密码
 立即注册
查看: 2307|回复: 4

[已解决]25课void指针和NULL指针课后题动动手 0 题答案的问题

[复制链接]
发表于 2018-4-21 11:11:11 | 显示全部楼层 |阅读模式
5鱼币
25课void指针和NULL指针课后题动动手 0 题答案的问题

1.第一次定义  matrix_in_1  和 matrix_in_2 的时候就已经错了吧,数组的下标不能是变量。
2.  row 取行数最大值  row = m > p ? m : p;  假设如题目给的打印结果 m=4,p=5 for外循环是5次,打印 matrix_in_1 部分时 不是应该有 5条 ‘|’ 的吗。
040130k4eostq0u1t94qv4.png
网上查了要用malloc才可以让用户自定义二维数组大小
还没运行成功,所以也不知道是不是和自己想的存在这些问题。?


#include <stdio.h>

int main()
{
        int m, p, n;
        int i, j, k, row;

        // 定义第一个矩阵
        printf("请输入第一个矩阵的尺寸(M * P):");
        scanf("%d * %d", &m, &p);
        int matrix_in_1[m][p];

        // 定义第二个矩阵
        printf("请输入第一个矩阵的尺寸(P * N):");
        scanf("%d * %d", &p, &n);
        int matrix_in_2[p][n];

        // 初始化存放乘积的二维数组
        // VAL数组不支持直接初始化操作
        int matrix_out[m][n];
        for (i = 0; i < m; i++)
        {
                for (j = 0; j < n; j++)
                {
                        matrix_out[j] = 0;
                }
        }

        // 让用户输入第一个矩阵
        printf("请输入第一个矩阵的值:\n");
        for (i = 0; i < m; i++)
        {
                for (j = 0; j < p; j++)
                {
                        scanf("%d", &matrix_in_1[j]);
                }
        }

        // 让用户输入第二个矩阵
        printf("请输入第二个矩阵的值:\n");
        for (i = 0; i < p; i++)
        {
                for (j = 0; j < n; j++)
                {
                        scanf("%d", &matrix_in_2[j]);
                }
        }

        // 计算乘积并保存
        for (i = 0; i < m; i++)
        {
                for (j = 0; j < n; j++)
                {
                        for (k = 0; k < p; k++)
                        {
                                matrix_out[j] += matrix_in_1[k] * matrix_in_2[k][j];
                        }
                }
        }

        printf("计算结果如下:\n");

        // row 取行数最大值
        row = m > p ? m : p;

        for (i = 0; i < row; i++)
        {
                printf("|  ");
                // 打印 matrix_in_1
                for (j = 0; j < p; j++)
                {
                        if (i < m)
                        {
                                printf("\b%d ", matrix_in_1[j]);
                                printf("|");
                        }
                        else
                        {
                                printf("\b\b\b     ");
                        }
                }
                // 打印 * 号
                if (i == row / 2)
                {
                        printf(" * ");
                }
                else
                {
                        printf("   ");
                }
                printf("|  ");
                // 打印 matrix_in_2
                for (j = 0; j < n; j++)
                {
                        if (i < p)
                        {
                                printf("\b%d ", matrix_in_2[j]);
                                printf("|");
                        }
                        else
                        {
                                printf("\b\b\b     ");
                        }
                }
                // 打印 = 号
                if (i == row / 2)
                {
                        printf(" = ");
                }
                else
                {
                        printf("   ");
                }
                // 打印 matrix_out
                printf("|  ");
                for (j = 0; j < n; j++)
                {
                        if (i < m)
                        {
                                printf("\b%d ", matrix_out[j]);
                                printf("|");
                        }
                        else
                        {
                                printf("\b\b\b      ");
                        }
                }
                printf("\n");
        }

        return 0;
}
最佳答案
2018-4-21 11:11:12
楼主你的程序里的那些赋值应该都是要对应到具体的元素上的,二维数组要两个下标才是元素值(例如Matrix[1][2]代表第二行第三个元素),要是一个下标如:Matrix[1]代表的是矩阵的第二行的地址,意思是不一样的!!!这个方面的知识还要巩固一下

下面这个是宏定义写的一个4x5矩阵和5x8矩阵的乘积
  1. #include <stdio.h>
  2. #define m 4//宏定义这里的变量名建议大写,但是楼主你的程序里都是小写,懒得改了
  3. #define p 5
  4. #define n 8
  5. int main()
  6. {
  7.         int i, j, k, row;

  8.         // 定义第一个矩阵
  9.         //printf("请输入第一个矩阵的尺寸(M * P):");
  10.         int matrix_in_1[m][p];

  11.         // 定义第二个矩阵
  12.         //printf("请输入第一个矩阵的尺寸(P * N):");
  13.         int matrix_in_2[p][n];

  14.         // 初始化存放乘积的二维数组
  15.         // VAL数组不支持直接初始化操作
  16.         int matrix_out[m][n];
  17.         for (i = 0; i < m; i++)
  18.         {
  19.                 for (j = 0; j < n; j++)
  20.                 {
  21.                         matrix_out[i][j] = 0;//这里要指定到具体的元素哇
  22.                 }
  23.         }

  24.         // 让用户输入第一个矩阵
  25.         printf("请输入第一个矩阵的值:\n");
  26.         for (i = 0; i < m; i++)
  27.         {
  28.                 for (j = 0; j < p; j++)
  29.                 {
  30.                         scanf("%d", &matrix_in_1[i][j]);//这里也是要具体到一个元素
  31.                 }
  32.         }

  33.         // 让用户输入第二个矩阵
  34.         printf("请输入第二个矩阵的值:\n");
  35.         for (i = 0; i < p; i++)
  36.         {
  37.                 for (j = 0; j < n; j++)
  38.                 {
  39.                         scanf("%d", &matrix_in_2[i][j]);//原因同上
  40.                 }
  41.         }

  42.         // 计算乘积并保存
  43.         for (i = 0; i < m; i++)
  44.         {
  45.                 for (j = 0; j < n; j++)
  46.                 {
  47.                         for (k = 0; k < p; k++)
  48.                         {
  49.                                 matrix_out[i][j] += matrix_in_1[i][k] * matrix_in_2[k][j];
  50.                         }
  51.                 }
  52.         }

  53.         printf("计算结果如下:\n");

  54.         // row 取行数最大值
  55.         row = m > p ? m : p;

  56.         for (i = 0; i < row; i++)
  57.         {
  58.                 printf("|  ");
  59.                 // 打印 matrix_in_1
  60.                 for (j = 0; j < p; j++)
  61.                 {
  62.                         if (i < m)
  63.                         {
  64.                                 printf("\b%d ", matrix_in_1[i][j]);
  65.                                 printf("|");
  66.                         }
  67.                         else
  68.                         {
  69.                                 printf("\b\b\b     ");
  70.                         }
  71.                 }
  72.                 // 打印 * 号
  73.                 if (i == row / 2)
  74.                 {
  75.                         printf(" * ");
  76.                 }
  77.                 else
  78.                 {
  79.                         printf("   ");
  80.                 }
  81.                 printf("|  ");
  82.                 // 打印 matrix_in_2
  83.                 for (j = 0; j < n; j++)
  84.                 {
  85.                         if (i < p)
  86.                         {
  87.                                 printf("\b%d ", matrix_in_2[i][j]);
  88.                                 printf("|");
  89.                         }
  90.                         else
  91.                         {
  92.                                 printf("\b\b\b     ");
  93.                         }
  94.                 }
  95.                 // 打印 = 号
  96.                 if (i == row / 2)
  97.                 {
  98.                         printf(" = ");
  99.                 }
  100.                 else
  101.                 {
  102.                         printf("   ");
  103.                 }
  104.                 // 打印 matrix_out
  105.                 printf("|  ");
  106.                 for (j = 0; j < n; j++)
  107.                 {
  108.                         if (i < m)
  109.                         {
  110.                                 printf("\b%d ", matrix_out[i][j]);
  111.                                 printf("|");
  112.                         }
  113.                         else
  114.                         {
  115.                                 printf("\b\b\b      ");
  116.                         }
  117.                 }
  118.                 printf("\n");
  119.         }

  120.         return 0;
  121. }
复制代码

这个程序还不能满足楼主的自定义输入矩阵的这个要求,下面就要初始化的时候就像楼主说的要用到malloc函数了,楼主说的对,数组在定义的时候那个下边里不能是变量的,所以我们要用malloc来动态申请空间
这个程序是要自己输入矩阵的规模的,就是楼主一开始的要求:
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         int i, j, k, row;
  5.         int m, p, n;

  6.         //定义第一个矩阵
  7.         printf("请输入第一个矩阵的尺寸(M * P):");
  8.         scanf("%d * %d", &m, &p);
  9.         int **matrix_in_1;
  10.         matrix_in_1 = (int**)malloc(sizeof(int*)*m);//第一个矩阵申请m行
  11.         for (i = 0; i < m; i++){
  12.                 matrix_in_1[i] = (int)malloc(sizeof(int)*p);//第一个矩阵申请p列
  13.         }

  14.         // 定义第二个矩阵
  15.         printf("请输入第一个矩阵的尺寸(P * N):");
  16.         scanf("%d * %d", &p, &n);
  17.         int **matrix_in_2;
  18.         matrix_in_2 = (int**)malloc(sizeof(int*)*p);//第二个矩阵申请p行
  19.         for (i = 0; i < p; i++){
  20.                 matrix_in_2[i] = (int)malloc(sizeof(int)*n);//第二个矩阵申请n行
  21.         }


  22.         // 初始化存放乘积的二维数组
  23.         // VAL数组不支持直接初始化操作
  24.         //int matrix_out[m][n];
  25.         int **matrix_out;
  26.         matrix_out = (int **)malloc(sizeof(int*)*m);//申请空间的原理同上
  27.         for (i = 0; i < m; i++){
  28.                 matrix_out[i] = (int)malloc(sizeof(int)*n);
  29.         }

  30.         //初始化,就是全部元素为零
  31.         for (i = 0; i < m; i++)
  32.         {
  33.                 for (j = 0; j < n; j++)
  34.                 {
  35.                         matrix_out[i][j] = 0;//这里要指定到具体的元素哇
  36.                 }
  37.         }

  38.         // 让用户输入第一个矩阵
  39.         printf("请输入第一个矩阵的值:\n");
  40.         for (i = 0; i < m; i++)
  41.         {
  42.                 for (j = 0; j < p; j++)
  43.                 {
  44.                         scanf("%d", &matrix_in_1[i][j]);//这里也是要具体到一个元素
  45.                 }
  46.         }

  47.         // 让用户输入第二个矩阵
  48.         printf("请输入第二个矩阵的值:\n");
  49.         for (i = 0; i < p; i++)
  50.         {
  51.                 for (j = 0; j < n; j++)
  52.                 {
  53.                         scanf("%d", &matrix_in_2[i][j]);//原因同上
  54.                 }
  55.         }

  56.         // 计算乘积并保存
  57.         for (i = 0; i < m; i++)
  58.         {
  59.                 for (j = 0; j < n; j++)
  60.                 {
  61.                         for (k = 0; k < p; k++)
  62.                         {
  63.                                 matrix_out[i][j] += matrix_in_1[i][k] * matrix_in_2[k][j];
  64.                         }
  65.                 }
  66.         }

  67.         printf("计算结果如下:\n");

  68.         // row 取行数最大值
  69.         row = m > p ? m : p;

  70.         for (i = 0; i < row; i++)
  71.         {
  72.                 printf("|  ");
  73.                 // 打印 matrix_in_1
  74.                 for (j = 0; j < p; j++)
  75.                 {
  76.                         if (i < m)
  77.                         {
  78.                                 printf("\b%d ", matrix_in_1[i][j]);
  79.                                 printf("|");
  80.                         }
  81.                         else
  82.                         {
  83.                                 printf("\b\b\b     ");
  84.                         }
  85.                 }
  86.                 // 打印 * 号
  87.                 if (i == row / 2)
  88.                 {
  89.                         printf(" * ");
  90.                 }
  91.                 else
  92.                 {
  93.                         printf("   ");
  94.                 }
  95.                 printf("|  ");
  96.                 // 打印 matrix_in_2
  97.                 for (j = 0; j < n; j++)
  98.                 {
  99.                         if (i < p)
  100.                         {
  101.                                 printf("\b%d ", matrix_in_2[i][j]);
  102.                                 printf("|");
  103.                         }
  104.                         else
  105.                         {
  106.                                 printf("\b\b\b     ");
  107.                         }
  108.                 }
  109.                 // 打印 = 号
  110.                 if (i == row / 2)
  111.                 {
  112.                         printf(" = ");
  113.                 }
  114.                 else
  115.                 {
  116.                         printf("   ");
  117.                 }
  118.                 // 打印 matrix_out
  119.                 printf("|  ");
  120.                 for (j = 0; j < n; j++)
  121.                 {
  122.                         if (i < m)
  123.                         {
  124.                                 printf("\b%d ", matrix_out[i][j]);
  125.                                 printf("|");
  126.                         }
  127.                         else
  128.                         {
  129.                                 printf("\b\b\b      ");
  130.                         }
  131.                 }
  132.                 printf("\n");
  133.         }

  134.         ////////////////////////////////////
  135.         //下面为释放malloc申请的三个矩阵的空间
  136.         ///////////////////////////////////
  137.         //先释放第一个矩阵的空间
  138.         for (i = 0; i < m; i++){
  139.                 free(matrix_in_1[i]);
  140.         }
  141.         free(matrix_in_1);
  142.        
  143.         //释放第二个矩阵的空间
  144.         for (i = 0; i < p; i++){
  145.                 free(matrix_in_2[i]);
  146.         }
  147.         free(matrix_in_2);

  148.         //释放存储结果的矩阵
  149.         for (i = 0; i < m; i++){
  150.                 free(matrix_out[i]);
  151.         }
  152.         free(matrix_out);

  153.         return 0;//程序正常结束
  154. }
复制代码



第二个程序的运行结果:
请输入第一个矩阵的尺寸(M * P):4 * 5
请输入第一个矩阵的尺寸(P * N):5 * 8
请输入第一个矩阵的值:
1 2 3 4 5
2 2 2 2 2
3 3 3 3 3
5 4 3 2 1
请输入第二个矩阵的值:
8 7 6 5 4 3 2 1
1 1 1 1 1 1 1 1
2 2 2 2 2 2 2 2
3 3 3 3 3 3 3 3
1 2 3 4 5 6 7 8
计算结果如下:
| 1 2 3 4 5 |   | 8 7 6 5 4 3 2 1 |   | 33 37 41 45 49 53 57 61 |
| 2 2 2 2 2 |   | 1 1 1 1 1 1 1 1 |   | 30 30 30 30 30 30 30 30 |
| 3 3 3 3 3 | * | 2 2 2 2 2 2 2 2 | = | 45 45 45 45 45 45 45 45 |
| 5 4 3 2 1 |   | 3 3 3 3 3 3 3 3 |   | 57 53 49 45 41 37 33 29 |
                | 1 2 3 4 5 6 7 8 |
请按任意键继续. . .

最佳答案

查看完整内容

楼主你的程序里的那些赋值应该都是要对应到具体的元素上的,二维数组要两个下标才是元素值(例如Matrix[1][2]代表第二行第三个元素),要是一个下标如:Matrix[1]代表的是矩阵的第二行的地址,意思是不一样的!!!这个方面的知识还要巩固一下 下面这个是宏定义写的一个4x5矩阵和5x8矩阵的乘积 这个程序还不能满足楼主的自定义输入矩阵的这个要求,下面就要初始化的时候就像楼主说的要用到malloc函数了,楼主说的对,数组在定 ...
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-21 11:11:12 | 显示全部楼层    本楼为最佳答案   
楼主你的程序里的那些赋值应该都是要对应到具体的元素上的,二维数组要两个下标才是元素值(例如Matrix[1][2]代表第二行第三个元素),要是一个下标如:Matrix[1]代表的是矩阵的第二行的地址,意思是不一样的!!!这个方面的知识还要巩固一下

下面这个是宏定义写的一个4x5矩阵和5x8矩阵的乘积
  1. #include <stdio.h>
  2. #define m 4//宏定义这里的变量名建议大写,但是楼主你的程序里都是小写,懒得改了
  3. #define p 5
  4. #define n 8
  5. int main()
  6. {
  7.         int i, j, k, row;

  8.         // 定义第一个矩阵
  9.         //printf("请输入第一个矩阵的尺寸(M * P):");
  10.         int matrix_in_1[m][p];

  11.         // 定义第二个矩阵
  12.         //printf("请输入第一个矩阵的尺寸(P * N):");
  13.         int matrix_in_2[p][n];

  14.         // 初始化存放乘积的二维数组
  15.         // VAL数组不支持直接初始化操作
  16.         int matrix_out[m][n];
  17.         for (i = 0; i < m; i++)
  18.         {
  19.                 for (j = 0; j < n; j++)
  20.                 {
  21.                         matrix_out[i][j] = 0;//这里要指定到具体的元素哇
  22.                 }
  23.         }

  24.         // 让用户输入第一个矩阵
  25.         printf("请输入第一个矩阵的值:\n");
  26.         for (i = 0; i < m; i++)
  27.         {
  28.                 for (j = 0; j < p; j++)
  29.                 {
  30.                         scanf("%d", &matrix_in_1[i][j]);//这里也是要具体到一个元素
  31.                 }
  32.         }

  33.         // 让用户输入第二个矩阵
  34.         printf("请输入第二个矩阵的值:\n");
  35.         for (i = 0; i < p; i++)
  36.         {
  37.                 for (j = 0; j < n; j++)
  38.                 {
  39.                         scanf("%d", &matrix_in_2[i][j]);//原因同上
  40.                 }
  41.         }

  42.         // 计算乘积并保存
  43.         for (i = 0; i < m; i++)
  44.         {
  45.                 for (j = 0; j < n; j++)
  46.                 {
  47.                         for (k = 0; k < p; k++)
  48.                         {
  49.                                 matrix_out[i][j] += matrix_in_1[i][k] * matrix_in_2[k][j];
  50.                         }
  51.                 }
  52.         }

  53.         printf("计算结果如下:\n");

  54.         // row 取行数最大值
  55.         row = m > p ? m : p;

  56.         for (i = 0; i < row; i++)
  57.         {
  58.                 printf("|  ");
  59.                 // 打印 matrix_in_1
  60.                 for (j = 0; j < p; j++)
  61.                 {
  62.                         if (i < m)
  63.                         {
  64.                                 printf("\b%d ", matrix_in_1[i][j]);
  65.                                 printf("|");
  66.                         }
  67.                         else
  68.                         {
  69.                                 printf("\b\b\b     ");
  70.                         }
  71.                 }
  72.                 // 打印 * 号
  73.                 if (i == row / 2)
  74.                 {
  75.                         printf(" * ");
  76.                 }
  77.                 else
  78.                 {
  79.                         printf("   ");
  80.                 }
  81.                 printf("|  ");
  82.                 // 打印 matrix_in_2
  83.                 for (j = 0; j < n; j++)
  84.                 {
  85.                         if (i < p)
  86.                         {
  87.                                 printf("\b%d ", matrix_in_2[i][j]);
  88.                                 printf("|");
  89.                         }
  90.                         else
  91.                         {
  92.                                 printf("\b\b\b     ");
  93.                         }
  94.                 }
  95.                 // 打印 = 号
  96.                 if (i == row / 2)
  97.                 {
  98.                         printf(" = ");
  99.                 }
  100.                 else
  101.                 {
  102.                         printf("   ");
  103.                 }
  104.                 // 打印 matrix_out
  105.                 printf("|  ");
  106.                 for (j = 0; j < n; j++)
  107.                 {
  108.                         if (i < m)
  109.                         {
  110.                                 printf("\b%d ", matrix_out[i][j]);
  111.                                 printf("|");
  112.                         }
  113.                         else
  114.                         {
  115.                                 printf("\b\b\b      ");
  116.                         }
  117.                 }
  118.                 printf("\n");
  119.         }

  120.         return 0;
  121. }
复制代码

这个程序还不能满足楼主的自定义输入矩阵的这个要求,下面就要初始化的时候就像楼主说的要用到malloc函数了,楼主说的对,数组在定义的时候那个下边里不能是变量的,所以我们要用malloc来动态申请空间
这个程序是要自己输入矩阵的规模的,就是楼主一开始的要求:
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         int i, j, k, row;
  5.         int m, p, n;

  6.         //定义第一个矩阵
  7.         printf("请输入第一个矩阵的尺寸(M * P):");
  8.         scanf("%d * %d", &m, &p);
  9.         int **matrix_in_1;
  10.         matrix_in_1 = (int**)malloc(sizeof(int*)*m);//第一个矩阵申请m行
  11.         for (i = 0; i < m; i++){
  12.                 matrix_in_1[i] = (int)malloc(sizeof(int)*p);//第一个矩阵申请p列
  13.         }

  14.         // 定义第二个矩阵
  15.         printf("请输入第一个矩阵的尺寸(P * N):");
  16.         scanf("%d * %d", &p, &n);
  17.         int **matrix_in_2;
  18.         matrix_in_2 = (int**)malloc(sizeof(int*)*p);//第二个矩阵申请p行
  19.         for (i = 0; i < p; i++){
  20.                 matrix_in_2[i] = (int)malloc(sizeof(int)*n);//第二个矩阵申请n行
  21.         }


  22.         // 初始化存放乘积的二维数组
  23.         // VAL数组不支持直接初始化操作
  24.         //int matrix_out[m][n];
  25.         int **matrix_out;
  26.         matrix_out = (int **)malloc(sizeof(int*)*m);//申请空间的原理同上
  27.         for (i = 0; i < m; i++){
  28.                 matrix_out[i] = (int)malloc(sizeof(int)*n);
  29.         }

  30.         //初始化,就是全部元素为零
  31.         for (i = 0; i < m; i++)
  32.         {
  33.                 for (j = 0; j < n; j++)
  34.                 {
  35.                         matrix_out[i][j] = 0;//这里要指定到具体的元素哇
  36.                 }
  37.         }

  38.         // 让用户输入第一个矩阵
  39.         printf("请输入第一个矩阵的值:\n");
  40.         for (i = 0; i < m; i++)
  41.         {
  42.                 for (j = 0; j < p; j++)
  43.                 {
  44.                         scanf("%d", &matrix_in_1[i][j]);//这里也是要具体到一个元素
  45.                 }
  46.         }

  47.         // 让用户输入第二个矩阵
  48.         printf("请输入第二个矩阵的值:\n");
  49.         for (i = 0; i < p; i++)
  50.         {
  51.                 for (j = 0; j < n; j++)
  52.                 {
  53.                         scanf("%d", &matrix_in_2[i][j]);//原因同上
  54.                 }
  55.         }

  56.         // 计算乘积并保存
  57.         for (i = 0; i < m; i++)
  58.         {
  59.                 for (j = 0; j < n; j++)
  60.                 {
  61.                         for (k = 0; k < p; k++)
  62.                         {
  63.                                 matrix_out[i][j] += matrix_in_1[i][k] * matrix_in_2[k][j];
  64.                         }
  65.                 }
  66.         }

  67.         printf("计算结果如下:\n");

  68.         // row 取行数最大值
  69.         row = m > p ? m : p;

  70.         for (i = 0; i < row; i++)
  71.         {
  72.                 printf("|  ");
  73.                 // 打印 matrix_in_1
  74.                 for (j = 0; j < p; j++)
  75.                 {
  76.                         if (i < m)
  77.                         {
  78.                                 printf("\b%d ", matrix_in_1[i][j]);
  79.                                 printf("|");
  80.                         }
  81.                         else
  82.                         {
  83.                                 printf("\b\b\b     ");
  84.                         }
  85.                 }
  86.                 // 打印 * 号
  87.                 if (i == row / 2)
  88.                 {
  89.                         printf(" * ");
  90.                 }
  91.                 else
  92.                 {
  93.                         printf("   ");
  94.                 }
  95.                 printf("|  ");
  96.                 // 打印 matrix_in_2
  97.                 for (j = 0; j < n; j++)
  98.                 {
  99.                         if (i < p)
  100.                         {
  101.                                 printf("\b%d ", matrix_in_2[i][j]);
  102.                                 printf("|");
  103.                         }
  104.                         else
  105.                         {
  106.                                 printf("\b\b\b     ");
  107.                         }
  108.                 }
  109.                 // 打印 = 号
  110.                 if (i == row / 2)
  111.                 {
  112.                         printf(" = ");
  113.                 }
  114.                 else
  115.                 {
  116.                         printf("   ");
  117.                 }
  118.                 // 打印 matrix_out
  119.                 printf("|  ");
  120.                 for (j = 0; j < n; j++)
  121.                 {
  122.                         if (i < m)
  123.                         {
  124.                                 printf("\b%d ", matrix_out[i][j]);
  125.                                 printf("|");
  126.                         }
  127.                         else
  128.                         {
  129.                                 printf("\b\b\b      ");
  130.                         }
  131.                 }
  132.                 printf("\n");
  133.         }

  134.         ////////////////////////////////////
  135.         //下面为释放malloc申请的三个矩阵的空间
  136.         ///////////////////////////////////
  137.         //先释放第一个矩阵的空间
  138.         for (i = 0; i < m; i++){
  139.                 free(matrix_in_1[i]);
  140.         }
  141.         free(matrix_in_1);
  142.        
  143.         //释放第二个矩阵的空间
  144.         for (i = 0; i < p; i++){
  145.                 free(matrix_in_2[i]);
  146.         }
  147.         free(matrix_in_2);

  148.         //释放存储结果的矩阵
  149.         for (i = 0; i < m; i++){
  150.                 free(matrix_out[i]);
  151.         }
  152.         free(matrix_out);

  153.         return 0;//程序正常结束
  154. }
复制代码



第二个程序的运行结果:
请输入第一个矩阵的尺寸(M * P):4 * 5
请输入第一个矩阵的尺寸(P * N):5 * 8
请输入第一个矩阵的值:
1 2 3 4 5
2 2 2 2 2
3 3 3 3 3
5 4 3 2 1
请输入第二个矩阵的值:
8 7 6 5 4 3 2 1
1 1 1 1 1 1 1 1
2 2 2 2 2 2 2 2
3 3 3 3 3 3 3 3
1 2 3 4 5 6 7 8
计算结果如下:
| 1 2 3 4 5 |   | 8 7 6 5 4 3 2 1 |   | 33 37 41 45 49 53 57 61 |
| 2 2 2 2 2 |   | 1 1 1 1 1 1 1 1 |   | 30 30 30 30 30 30 30 30 |
| 3 3 3 3 3 | * | 2 2 2 2 2 2 2 2 | = | 45 45 45 45 45 45 45 45 |
| 5 4 3 2 1 |   | 3 3 3 3 3 3 3 3 |   | 57 53 49 45 41 37 33 29 |
                | 1 2 3 4 5 6 7 8 |
请按任意键继续. . .
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-21 12:35:52 | 显示全部楼层
以上程序仅供参考,至于那个杠杠的格式化问题就是楼主自己在琢磨一下吧,我感觉我运行起来格式挺整齐的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-4-21 23:11:02 | 显示全部楼层
溯影 发表于 2018-4-21 12:35
以上程序仅供参考,至于那个杠杠的格式化问题就是楼主自己在琢磨一下吧,我感觉我运行起来格式挺整齐的{:10 ...

多谢哈,我发的那串代码是小甲鱼的答案,觉得有问题但是那一课还没到动态内存部分,所以问一下还有没别的方法可以处理
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-22 08:17:44 | 显示全部楼层
卖鱼熊 发表于 2018-4-21 23:11
多谢哈,我发的那串代码是小甲鱼的答案,觉得有问题但是那一课还没到动态内存部分,所以问一下还有没别的 ...

一起学习一下了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-26 21:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表