本文目錄一覽:
怎樣用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語言怎麼定義 一個動態n階矩陣,n是一個變量
#includestdio.h
int main()
{
int n;
int **p;
int i;
scanf(“%d”,n);
p=new int*[n];
for(i=0;in;i++)
{
p[i]=new int [n];
}
return 0;
}
C語言也可以用new開闢空間,要是覺得彆扭的話你也可以用malloc開闢,都差不多,我只是覺得用new比較容易看懂,用malloc開闢的話你可以參照最快回答
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(“請輸入要獲取的行數和列數:\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;
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/270745.html