日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

一個棘手的程序~~

 昵稱71201 2008-08-25
  一個使用C++的練習題,但是不知道哪里出的錯,能編譯,能build,就是運行的時候,內存出錯~~
  想知道哪里出的錯~~或者,給出這個題你的程序~~
================================================================
題目是:
 

寫一個程序,當給出下面的輸入文件input.txt時,計算矩陣a,b,c的乘積,求input.txt第一行給出的那個位置上的元素~~~~~最后輸出到output.txt

 

其中 :矩陣a,b,c都是稀疏矩陣~~

 

 

input.txt

1 2                     //要算的矩陣d 的某元素的行列數

3 4 2 3                 //矩陣a,b,c分別為3行4列,4行2列,2行3列

1 1 3                   //矩陣a的第一行,第一列元素為3

1 4 5                   //同理

2 2 1                   //同理

3 1 2                   //同理

 

1 2 2                    //矩陣b的第一行,第二列元素為2

2 1 1

3 1 2

3 2 4

 

1 2 2                    //矩陣c的第一行,第二列元素為2

1 3 3

2 1 1

2 2 2

 

 

 

===================================================================================

我寫得程序:

 

#include<string>
#include<iostream>
#include<fstream>

using namespace std;
void main()
{
int i,j;
int m,n;
int a,b,c,row1,row2,row3,row4;


ifstream input("add.txt");
ofstream output("result.txt");

input>>m;             //存入input第一行第一個數作為最后要求的那個數的行標
input>>n;             //存入input第一行第二個數作為最后要求的那個數的列標
input>>row1;
input>>row2;
input>>row3;
input>>row4;

int **ai=new int*[row1];//根據讀入的行、列數動態(tài)定義數組大小 ,生成第一個矩陣
for (i = 0; i < row1; ++i)
 {
ai[i] = new int[row2];
}
int **bi=new int*[row2];//根據讀入的行、列數動態(tài)定義數組大小 ,生成第二個矩陣
for (i = 0; i < row2; ++i)
 {
bi[i] = new int[row3];
}
int **ci=new int*[row3];//根據讀入的行、列數動態(tài)定義數組大小 ,生成第三個矩陣
for (i = 0; i < row3; ++i)
{
ci[i] = new int[row4];
}


 for(i=0;i<row1;i++)          //把每個矩陣都填充為0
 for(j=0;j<row2;j++)
  ai[i][j]=0;
 for(i=0;i<row2;i++)
 for(j=0;j<row3;j++)
  bi[i][j]=0;
 for(i=0;i<row3;i++)
 for(j=0;j<row4;j++)
  ci[i][j]=0;


int count=0;                               //從這里開始,將input中的數填充到對應矩陣中
while(input.good() && !input.eof())
{
input>>a;
    if(a>=count)    count=a;
  else break;
input>>b;
input>>c;
ai[a][b]=c;
}

input>>b;
input>>c;
bi[a][b]=c;

count=0;
while(input.good() && !input.eof())
{
input>>a;
    if(a>=count)    count=a;
  else break;
input>>b;
input>>c;
bi[a][b]=c;
}


input>>b;
input>>c;
ci[a][b]=c;


count=0;
while(input.good() && !input.eof())
{
input>>a;
    if(a>=count)    count=a;
  else break;
input>>b;
input>>c;
ci[a][b]=c;


int g[30],e=0;                      //最后計算所求的那個數
for(int k=0;k<row3;k++)
{
 for( int i=0;i<row2;i++)
   {
    e=ai[m][i]*bi[i][k];
       g[k]=g[k]+e;
    }
}

int t=0;

for(k=0;k<row3;k++)
{e=g[k]*ci[k][n];
t=t+e;}

output<<t<<endl;
}

 


    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯系方式、誘導購買等信息,謹防詐騙。如發(fā)現有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多