c - 为什么我的 C 程序应该输出 n 次方矩阵,却输出 2^n 次方矩阵?

标签 c linux unix matrix matrix-multiplication

我的代码应该接受矩阵 M 并将其计算为整数 A 的幂。但是,不知何故,我的输出始终是 M^(2^A)。例如,如果我想找到一个矩阵的 3 次方,我将得到它的 8 次方。

#include <stdio.h> 
#include <stdlib.h> 
#include <math.h>
  void multiply(int ** p, int pwr, int dim, int ** prod) {
    int m, i, j, k;
    /*if (n<pwr){*/
    int pos = 0;
    for (m = 0; m < pwr; m++) {
      for (i = 0; i < dim; i++) {
        for (j = 0; j < dim; j++) {
          for (k = 0; k < dim; k++) {
            pos += p[i][k] * p[k][j];
          }
          prod[i][j] = pos;
          pos = 0;
        }
      }
      for (i = 0; i < dim; i++) {
        for (j = 0; j < dim; j++) {
          p[i][j] = prod[i][j];
          prod[i][j] = 0;
        }
      }
    }
    /*n=n+1;
    multiply(prod, q, pwr, dim, prod);
    }*/
  }
int main(int argc, char * argv[]) {
  FILE * fp = fopen(argv[1], "r");
  int dim, pwr, i, j;
  fscanf(fp, "%d", & dim);
  int ** matrix;
  matrix = (int ** ) malloc(dim * sizeof(int * ));
  for (i = 0; i < dim; i++) {
    matrix[i] = (int * ) malloc(dim * sizeof(int));
  }
  int ** prod;
  prod = (int ** ) malloc(dim * sizeof(int * ));
  for (i = 0; i < dim; i++) {
    prod[i] = (int * ) malloc(dim * sizeof(int));
  }
  for (i = 0; i < dim; i++) {
    for (j = 0; j < dim; j++) {
      fscanf(fp, "%d", & matrix[i][j]);
    }
  }
  fscanf(fp, "%d", & pwr);
  if (pwr == 1) {
    for (i = 0; i < dim; i++) {
      for (j = 0; j < dim; j++) {
        printf("%d ", matrix[i][j]);
      }
      printf("\n");
    }
  } else if (pwr >= 2) {
    multiply(matrix, pwr, dim, prod);
    for (i = 0; i < dim; i++) {
      for (j = 0; j < dim; j++) {
        printf("%d ", matrix[i][j]);
      }
      printf("\n");
    }
  }
  return 0;
}

最佳答案

您将矩阵与其自身相乘,然后将结果存储在原始矩阵中。然后你再做一次。

非常正常,它可以通电 8 次。您需要的是另一个临时矩阵,您可以在其中存储结果并保留原始矩阵以与结果相乘。

关于c - 为什么我的 C 程序应该输出 n 次方矩阵,却输出 2^n 次方矩阵?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52802552/

相关文章:

C Windows 缓冲区大小

linux - 当我尝试获取 ~/.bashrc 时没有 .sc_start 文件

linux - 使用 SoX 将 mp3 文件拆分为 TIME 秒

c - 链接列表无法正常工作

c++ - 如何从进程内部确定 CPU 和内存消耗

C程序: Checking digits entered are 1s and 0s only using arrays

linux - 如何在 openldap 复制(synrepl)中使用 slapadd 添加条目

php - UNIX时间是否记录Timezone?

linux - 第一次出现数字后的 grep 字符串

unix - Unix中的硬链接(hard link)和符号链接(symbolic link)