ep5_4.cpp
上传用户:wxcui2006
上传日期:2022-07-12
资源大小:1274k
文件大小:2k
源码类别:

书籍源码

开发平台:

Visual C++

  1. /* 5.4  将[例5.5]改用一维数组,附加行、列参数,实现通用算法。*/
  2. #include <iostream>
  3. #include <iomanip>
  4. using namespace std;
  5. void inverse(int [], int [],int,int);//注意数组最高维可缺省,例5.5因初学未省
  6. void multi(int [], int [], int [],int,int,int);
  7. void output(int [],int,int);
  8. int main(){
  9.     int middle[6*3], result[6*4];//注意写作6*3等可清楚看出矩阵的行列
  10.     int matrix1[3*6]={8,10,12,23,1,3,5,7,9,2,4,6,34,45,56,2,4,6};   
  11.     int matrix2[3*4]={3,2,1,0,-1,-2,9,8,7,6,5,4};
  12. output(matrix1,3,6);
  13. inverse(matrix1,middle,3,6);
  14. output(middle,6,3);
  15. output(matrix2,3,4);
  16.    multi(middle,matrix2,result,6,3,4);
  17.     output(result,6,4);
  18. return 0;
  19. }
  20. void inverse(int matrix1_1[],int middle_1[],int a,int b){            
  21.     int i,j;
  22.     for (i=0;i<a;i++)
  23.       for (j=0;j<b;j++)
  24.         middle_1[i+j*a]=matrix1_1[i*b+j];                           
  25.     return;                                                      
  26. }
  27. void multi(int middle_1[],int matrix2_1[],int result_1[],int a,int b,int c){                                                                    
  28.     int i,j,k;
  29.     for (i=0;i<a;i++){
  30.       for (j=0;j<c;j++){
  31.         result_1[i*c+j] = 0;
  32.         for (k=0;k<b;k++)
  33.           result_1[i*c+j]+=middle_1[i*b+k]*matrix2_1[k*c+j];
  34.       }
  35.     }
  36.     return;
  37. }
  38. void output(int max_1[],int a,int b){
  39. for (int i=0;i<a;i++){
  40.       for (int j=0;j<b;j++)
  41.         cout <<setw(4)<<max_1[i*b+j]<<"  ";
  42.       cout<<'n';
  43.     }
  44. cout<<endl;
  45.     return;                                                       
  46. }