真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

c語言中創(chuàng)建矩陣函數(shù) c語言怎么做矩陣

c語言編程問題:矩陣的建立與運(yùn)算

你這是求助還是出題考別人呀?

站在用戶的角度思考問題,與客戶深入溝通,找到溫嶺網(wǎng)站設(shè)計(jì)與溫嶺網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站建設(shè)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊(cè)、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋溫嶺地區(qū)。

回答者:starway1982 - 試用期 一級(jí)

就是,問問題要謙虛

怎樣用C語言寫矩陣?

用二維數(shù)組,如下:

#include stdio.h

main()

{

int i, j, a[4][4];

for ( i = 1; i 4; i++ )

{

for ( j = 1; j 4; j++ )

{

scanf ("%d", a[i][j]);

}

}

//這樣就可以將一個(gè)3*3 的矩陣存在2維數(shù)組中了

for ( i = 1; i 4; i++ )

{

for ( j = 1; j 4; j++ )

{

printf (" %-4d ", a[i][j]);

}

printf ("\n");

}

//這樣就可以顯示矩陣

return 0;

}

c語言,矩陣

上面那個(gè)程序是我寫的,下面寫的是兩個(gè)2*2矩陣相加和相乘的程序(行數(shù)和列數(shù)可以在主函數(shù)中更改),不得不說一句,有關(guān)矩陣的東西就是麻煩:

#include stdio.h

#include stdlib.h

int** NewMatrix(int row,int col) //動(dòng)態(tài)開辟一個(gè)數(shù)組

{

int i,j;

int** matrix;

matrix=(int **)malloc(sizeof(int *)*row);

for(i=0;irow;i++)

{

matrix[i]=(int*)malloc(sizeof(int)*col);

}

//輸入矩陣的元素

printf("please input the array elements:\n") ;

for(i=0;irow;i++)

{

for(j=0;jcol;j++)

{

scanf("%d",matrix[i][j]);

}

}

return matrix;

}

//兩矩陣相加a[row][col]+b[row][col]

int **addMatrix(int** a,int** b,int row,int col)

{

int i,j;

int** matrix;

//動(dòng)態(tài)建立一個(gè)矩陣空間以存放運(yùn)算結(jié)果

matrix=(int **)malloc(sizeof(int *)*row);

for(i=0;irow;i++)

{

matrix[i]=(int*)malloc(sizeof(int)*col);

}

//計(jì)算a+b

for(i=0;irow;i++)

{

for(j=0;jcol;j++)

{

matrix[i][j] = a[i][j] + b[i][j];

}

}

return matrix;

}

//兩矩陣相乘a[row][com]*b[com][col]

int **multiplyMatrix(int **a,int **b,int row,int com,int col)

{

int i,j,k;

int** matrix;

//動(dòng)態(tài)建立一個(gè)矩陣空間以存放運(yùn)算結(jié)果

matrix=(int **)malloc(sizeof(int *)*row);

for(i=0;irow;i++)

{

matrix[i]=(int*)malloc(sizeof(int)*col);

}

//計(jì)算a+b

for(i=0;irow;i++)

{

for(j=0;jcol;j++)

{

matrix[i][j] = 0;

for(k=0;kcom;k++)

{

matrix[i][j] += a[i][k] * b[k][j];

}

}

}

return matrix;

}

void main()

{

int i,j;

int row = 2,col = 2; //行數(shù)和列數(shù)在此更改

int **a,**b,**c;

a = NewMatrix(row,col); //動(dòng)態(tài)建立矩陣a

b = NewMatrix(row,col); //動(dòng)態(tài)建立矩陣b

//調(diào)用函數(shù),求兩矩陣的和

c = addMatrix(a,b,row,col);

//輸出兩矩陣的和

printf("\na add b is:\n");

for(i=0;irow;i++)

{

printf("\n");

for(j=0;jcol;j++)

{

printf("%d ",c[i][j]);

}

}

//調(diào)用函數(shù),求兩矩陣的積

c = multiplyMatrix(a,b,row,row,col);

//輸出兩矩陣的積

printf("\na multiply b is:\n");

for(i=0;irow;i++)

{

printf("\n");

for(j=0;jcol;j++)

{

printf("%d ",c[i][j]);

}

}

}

本來程序還可以寫得簡(jiǎn)單一些,由于你要求兩矩陣同時(shí)能夠相加和相乘,從而可以判定兩矩陣的行數(shù)和列數(shù)應(yīng)該是相等的,因而在函數(shù)傳遞參數(shù)的時(shí)候只要傳一個(gè)就行了。但是考慮到程序的可移植性,我在寫相加和相乘的子函數(shù)時(shí),考慮了普遍性,即對(duì)于給定的任意的row和col(甚至row != col),加法和乘法都能夠適用。然而這樣一來,形參看起來就比較多了。你自己就情況而定吧,不懂的地方發(fā)我消息。

C語言中如何定義矩陣?

兩種方式可以參考:

1、最簡(jiǎn)單的就是二維數(shù)組,比如存儲(chǔ)全是整形的一個(gè)m*n的矩陣。然后可以定義int a[m][n]。

輸入或者輸出可以用兩層循環(huán)來完成,外層控制行m比如for(i=0;im;++i),內(nèi)層控制列n比如for(j=0;jn;++j);

2、第二種方式就是壓縮矩陣進(jìn)行存儲(chǔ),如果學(xué)了數(shù)據(jù)結(jié)構(gòu)應(yīng)該比較好理解。

結(jié)構(gòu)體進(jìn)行封裝,比如:

第一步:先定義一個(gè)有效數(shù)據(jù)的位置

typedef struct node

{

int hang;int lie;int data;//用來存儲(chǔ)一個(gè)有效數(shù)據(jù)位的行列和值

}node;

typedef struct matrix

{

node *m;//一個(gè)數(shù)組,用來存儲(chǔ)所有的node數(shù)據(jù)

int sum;//記錄一共有多少個(gè)有效數(shù)據(jù)位

}matrix;

c語言矩陣怎么寫?

方法1:直接定義10*10的數(shù)組,讀取全部數(shù)據(jù),再根據(jù)選擇的行列數(shù)打印輸出部分?jǐn)?shù)據(jù)。

方法2:通過文件流指針的移動(dòng),跨過不需要的內(nèi)容。(這里控制文件流指針可利用ftell和fseek函數(shù)來移動(dòng)指定字節(jié)數(shù))我是利用fscanf讀取需要的內(nèi)容,遇到需要跳行就用fgets來跳過。(注意常量參數(shù)根據(jù)自己需求修改)。

說明:邊讀取邊打印輸出,就不需要變量存儲(chǔ)。我的代碼是把讀取出來的內(nèi)容存放在三維數(shù)組中(文件內(nèi)容你沒指定,如是單純數(shù)字,二維數(shù)組即可,我是作為字符串處理,故用三維數(shù)組。),數(shù)組是根據(jù)實(shí)際大小,動(dòng)態(tài)申請(qǐng),寫成兩個(gè)獨(dú)立函數(shù)。

下面是代碼:

#include stdio.h

#include string.h

#include malloc.h

#define MAXR 10//文件中矩陣最大行

#define MAXC 10//文件中矩陣最大列

#define MS 3//矩陣中元素字符串最大字符數(shù)(包含結(jié)束符號(hào),不可小于實(shí)際內(nèi)容)

#define MBUF 100//文件中一行最大字符數(shù),可設(shè)置大一點(diǎn)

char ***getMem(int r,int c,int len);//動(dòng)態(tài)申請(qǐng)一個(gè)三維數(shù)組

void freeMem(char ***datas,int r,int c);//釋放數(shù)組空間

void showDatas(char ***datas,int r,int c);//打印輸出結(jié)果

int main()

{

int r=MAXR+1,c=MAXC+1,i=0,j=0;

char ***datas=NULL,str[3],buf[MBUF];

FILE *fp=NULL;

printf("請(qǐng)輸入要獲取的行數(shù)和列數(shù):\n");

while(r0 || rMAXR || c0 || cMAXC)scanf("%d%d",r,c);

datas=getMem(r,c,MS);

fp=fopen("C:\\test.data","r");

if(!fp) return 1;

while(fscanf(fp,"%s",str)!=-1)

{

? if(ic) strcpy(datas[j][i],str),i++;

? if(i==c)

? {

? ? ? if(!fgets(buf,sizeof(buf),fp)) break;

? ? ? i=0,j++;

? }

? if(j==r) break;

}

showDatas(datas,r,c);

freeMem(datas,r,c);

return 0;

}

void showDatas(char ***datas,int r,int c)

{

int i,j;

for(i=0;ir;i++,printf("\n"))

? for(j=0;jc;j++)

? ? ? printf("%s ",datas[i][j]);

printf("\n");

}

void freeMem(char ***datas,int r,int c)

{

int i,j;

if(!datas)

{

? for(i=0;ir;i++,free(datas[i]))

? ? ? for(j=0;jc;j++)

? ? ? ? ? free(datas[i][j]);

? free(datas);

}

}

char ***getMem(int r,int c,int len)

{

int i,j;

char ***datas=NULL,**dr=NULL;

datas=(char ***)malloc(sizeof(char **)*r);

if(!datas) return NULL;

for(i=0;ir;i++)

{

? dr=(char **)malloc(sizeof(char *)*c);

? if(!dr) return NULL;

? else

? {

? ? ? for(j=0;jc;j++)

? ? ? {

? ? ? ? ? dr[j]=(char *)malloc(sizeof(char)*len);

? ? ? ? ? if(!dr[j]) return NULL;

? ? ? }

? ? ? datas[i]=dr;

? }

}

return datas;

}


新聞標(biāo)題:c語言中創(chuàng)建矩陣函數(shù) c語言怎么做矩陣
本文網(wǎng)址:http://weahome.cn/article/hphpjh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部