f0815.cpp
资源名称:c.rar [点击查看]
上传用户:puke2000
上传日期:2022-07-25
资源大小:912k
文件大小:2k
源码类别:

C#编程

开发平台:

Visual C++

  1. //=====================================
  2. // f0815.cpp
  3. // normal function accessing class member
  4. //=====================================
  5. #include<iostream>
  6. #include<fstream>
  7. using namespace std;
  8. //-------------------------------------
  9. class Vector{
  10.   int* v;             //指向一个数组,表示向量
  11.   int sz;
  12. public:
  13.   void remove(){ delete[] v; }
  14.   int size(){ return sz; }
  15.   void set(int);
  16.   void display();
  17.   int& operator[](int);
  18. };//-----------------------------------
  19. void Vector::set(int s){
  20.   sz = s;
  21.   if(s<=0){
  22.     cerr<<"bad Vector size.n";
  23.     exit(1);
  24.   }
  25.   v = new int[s];
  26. }//------------------------------------
  27. int& Vector::operator[](int i){          //引用返回的目的是返回值可以作左值
  28.   if(i<0 || i>=sz){
  29.     cerr <<"Vector index out of range.n";
  30.     exit(1);
  31.   }
  32.   return v[i];
  33. }//------------------------------------
  34. void Vector::display(){
  35.   for(int i=0; i<sz; ++i)
  36.     cout<<v[i]<<" ";
  37.   cout<<"n";
  38. }//------------------------------------
  39. class Matrix{
  40.   int* m;
  41.   int szl, szr;
  42. public:
  43.   void set(int, int);
  44.   void remove(){ delete[] m; }
  45.   int sizeL(){ return szl; }
  46.   int sizeR(){ return szr; }
  47.   int& elem(int, int);
  48. };//-----------------------------------
  49. void Matrix::set(int i, int j){
  50.   szl = i; szr = j;
  51.   if(i<=0 || j<=0){
  52.     cerr <<"bad Matrix size.n";
  53.     exit(1);
  54.   }
  55.   m = new int[i*j];
  56. }//------------------------------------
  57. int& Matrix::elem(int i, int j){      //引用返回的目的是返回值可以作左值
  58.   if(i<0||szl<=i||j<0||szr<=j){
  59.     cerr <<"Matrix index out of range.n";
  60.     exit(1);
  61.   }
  62.   return m[i*szr+j];
  63. }//------------------------------------
  64. Vector multiply(Matrix& m, Vector& v){  //矩阵乘向量
  65.   if(m.sizeR()!=v.size()){
  66.     cerr <<"bad multiply Matrix with Vector.n";
  67.     exit(1);
  68.   }
  69.   Vector r;
  70.   r.set(m.sizeL());       //创建一个存放结果的空向量
  71.   for(int i=0; i<m.sizeL(); i++){
  72.     r[i] = 0;
  73.     for(int j=0; j<m.sizeR(); j++)
  74.       r[i] += m.elem(i,j) * v[j];
  75.   }
  76.   return r;
  77. }//------------------------------------
  78. int main(){
  79.   ifstream in("in.txt");
  80.   int x,y;  in>>x>>y;
  81.   Matrix ma;
  82.   ma.set(x,y);
  83.   for(int i=0; i<x; ++i)
  84.   for(int j=0; j<y; ++j)
  85.     in>>ma.elem(i,j);
  86.   in>>x;
  87.   Vector ve;
  88.   ve.set(x);
  89.   for(int i=0; i<x; ++i)
  90.     in>>ve[i];
  91.   Vector vx = multiply(ma,ve);
  92.   vx.display();
  93.   ma.remove();
  94.   ve.remove();
  95.   vx.remove();
  96. }//====================================
  97.