當前位置:首頁 » 編程語言 » 單位矩陣的用c語言表示方法
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

單位矩陣的用c語言表示方法

發布時間: 2022-08-18 12:51:43

c語言 如何表示矩陣

二維數組
int[10][10]就是一個10*10的二維數組

② c語言單位矩陣怎麼編程

你這個for循環後面有個分號,肯定不對
列印矩陣還是用雙重循環比較好。
#include <stdio.h>
int main()
{
int n=5,i,j;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
if(i==j)
printf("1 ");
else
printf("0 ");
printf("\n");
}
return 0;
}

③ 怎樣用一個3-5句的語言寫一個n維的單位矩陣,求c語言和matlab各一個。

#include<stdio.h>

intmain(){
inti,j,n;
while(scanf("%d",&n)==1){
for(i=0;i<n;++i){
for(j=0;j<n;++j)
printf("%d",i==j);
printf(" ");
}
}
return0;
}

④ c語言,矩陣

上面那個程序是我寫的,下面寫的是兩個2*2矩陣相加和相乘的程序(行數和列數可以在主函數中更改),不得不說一句,有關矩陣的東西就是麻煩:
#include <stdio.h>
#include <stdlib.h>

int** NewMatrix(int row,int col) //動態開辟一個數組
{
int i,j;
int** matrix;
matrix=(int **)malloc(sizeof(int *)*row);
for(i=0;i<row;i++)
{
matrix[i]=(int*)malloc(sizeof(int)*col);
}
//輸入矩陣的元素
printf("please input the array elements:\n") ;
for(i=0;i<row;i++)
{
for(j=0;j<col;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;
//動態建立一個矩陣空間以存放運算結果
matrix=(int **)malloc(sizeof(int *)*row);
for(i=0;i<row;i++)
{
matrix[i]=(int*)malloc(sizeof(int)*col);
}
//計算a+b
for(i=0;i<row;i++)
{
for(j=0;j<col;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;
//動態建立一個矩陣空間以存放運算結果
matrix=(int **)malloc(sizeof(int *)*row);
for(i=0;i<row;i++)
{
matrix[i]=(int*)malloc(sizeof(int)*col);
}
//計算a+b
for(i=0;i<row;i++)
{
for(j=0;j<col;j++)
{
matrix[i][j] = 0;
for(k=0;k<com;k++)
{
matrix[i][j] += a[i][k] * b[k][j];
}
}
}
return matrix;
}

void main()
{
int i,j;
int row = 2,col = 2; //行數和列數在此更改
int **a,**b,**c;
a = NewMatrix(row,col); //動態建立矩陣a
b = NewMatrix(row,col); //動態建立矩陣b
//調用函數,求兩矩陣的和
c = addMatrix(a,b,row,col);
//輸出兩矩陣的和
printf("\na add b is:\n");
for(i=0;i<row;i++)
{
printf("\n");
for(j=0;j<col;j++)
{
printf("%d ",c[i][j]);
}
}
//調用函數,求兩矩陣的積
c = multiplyMatrix(a,b,row,row,col);
//輸出兩矩陣的積
printf("\na multiply b is:\n");
for(i=0;i<row;i++)
{
printf("\n");
for(j=0;j<col;j++)
{
printf("%d ",c[i][j]);
}
}
}
本來程序還可以寫得簡單一些,由於你要求兩矩陣同時能夠相加和相乘,從而可以判定兩矩陣的行數和列數應該是相等的,因而在函數傳遞參數的時候只要傳一個就行了。但是考慮到程序的可移植性,我在寫相加和相乘的子函數時,考慮了普遍性,即對於給定的任意的row和col(甚至row != col),加法和乘法都能夠適用。然而這樣一來,形參看起來就比較多了。你自己就情況而定吧,不懂的地方發我消息。

⑤ C語言中的矩陣是怎樣計算的

矩陣的表示使用二維數組,當然二維數組通常情況下是不可以動態分配的,因此最好已開始定義一個足夠大的數組來存放矩陣元素。至於加減乘逆等運算,主要是利用嵌套循環操作其單個元素,由於每個人的方法不一樣就不詳細說了。希望對你有所幫助。

⑥ 如何用C語言定義矩陣

矩陣其實就是二維數組,在進行編碼的時候,矩陣就會被定義成為二維數組

⑦ c語言怎麼輸入矩陣

c語言矩陣分為兩種:

第一種方法是動態的申請矩陣存儲空間,該方法的好處有以下兩點:

1.能夠動態的申請和釋放存儲空間;

2.對於將矩陣作為函數返回值的情況,該方法具有獨特的優勢。

⑧ 怎樣用C語言寫矩陣

用二維數組,如下:
#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]);
}
}
//這樣就可以將一個3*3 的矩陣存在2維數組中了

for ( i = 1; i < 4; i++ )
{
for ( j = 1; j < 4; j++ )
{
printf (" %-4d ", a[i][j]);
}
printf ("\n");
}
//這樣就可以顯示矩陣
return 0;
}

⑨ c語言矩陣怎麼寫

方法1:直接定義10*10的數組,讀取全部數據,再根據選擇的行列數列印輸出部分數據。

方法2:通過文件流指針的移動,跨過不需要的內容。(這里控制文件流指針可利用ftell和fseek函數來移動指定位元組數)我是利用fscanf讀取需要的內容,遇到需要跳行就用fgets來跳過。(注意常量參數根據自己需求修改)。

說明:邊讀取邊列印輸出,就不需要變數存儲。我的代碼是把讀取出來的內容存放在三維數組中(文件內容你沒指定,如是單純數字,二維數組即可,我是作為字元串處理,故用三維數組。),數組是根據實際大小,動態申請,寫成兩個獨立函數。

下面是代碼:

#include <stdio.h>

#include <string.h>

#include <malloc.h>

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

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

#define MS 3//矩陣中元素字元串最大字元數(包含結束符號,不可小於實際內容)

#define MBUF 100//文件中一行最大字元數,可設置大一點

char ***getMem(int r,int c,int len);//動態申請一個三維數組

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

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

int main()

{

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

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

FILE *fp=NULL;

printf("請輸入要獲取的行數和列數: ");

while(r<0 || r>MAXR || c<0 || c>MAXC)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(i<c) 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;i<r;i++,printf(" "))

for(j=0;j<c;j++)

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

printf(" ");

}

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

{

int i,j;

if(!datas)

{

for(i=0;i<r;i++,free(datas[i]))

for(j=0;j<c;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;i<r;i++)

{

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

if(!dr) return NULL;

else

{

for(j=0;j<c;j++)

{

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

if(!dr[j]) return NULL;

}

datas[i]=dr;

}

}

return datas;

}

⑩ C語言中如何定義矩陣

兩種方式可以參考:
1、最簡單的就是二維數組,比如存儲全是整形的一個m*n的矩陣。然後可以定義int a[m][n]。
輸入或者輸出可以用兩層循環來完成,外層控制行m比如for(i=0;i<m;++i),內層控制列n比如for(j=0;j<n;++j);
2、第二種方式就是壓縮矩陣進行存儲,如果學了數據結構應該比較好理解。
結構體進行封裝,比如:
第一步:先定義一個有效數據的位置
typedef struct node
{
int hang;int lie;int data;//用來存儲一個有效數據位的行列和值
}node;
typedef struct matrix
{
node *m;//一個數組,用來存儲所有的node數據
int sum;//記錄一共有多少個有效數據位
}matrix;