㈠ 如何用c語言定義矩陣
矩陣其實就是二維數組,在進行編碼的時候,矩陣就會被定義成為二維數組
㈡ c語言定義矩陣
函數的參數不是這么定義的。。。。
int matrixMultiply(int **a,int **b,int **c,int ra,int ca,int rb,int cb);
這樣子應該可以吧。
㈢ 關於C語言結構體定義一個矩陣
#defineMAX100//保證矩陣長度不超過100,但如此定義會有內存浪費
structmatrix
{
intm;
intn;
double[MAX][MAX];
};
㈣ 如何使用C語言定義一個矩陣,矩陣里的元素都是字元串呢
可以的。在賦值的時候,要用到strcpy()函數將一個字元串復制到矩陣里。
act action[10][10];
假如給[i][j]號元素賦值:
char str[10] = "hello";
strcpy(action[i][j].arr, str);
㈤ 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語言 矩陣
這個注釋很清晰啊,樓主有什麼不明白的啊??我的QQ是414960867。。。
㈦ 關於C語言結構體定義一個矩陣
不能使用變數數組定義數組。
只能使用常量定義也就是:
double matrix[10][20].
或者使用:
const int a=10,b=20;
double matrix[a][b].
當然這樣有個壞處就是矩陣大小靜態限定死。
所以需要採用動態定義,即:
int a = 10, b = 20;
double **matrix;
matrix = new double*[a];
for (int i = 1; i <= 10; ++i)
matrix[i] = new double[b];
㈧ 用c語言定義申請一個動態矩陣,怎樣給動態矩陣怎樣賦初值
#include<stdlib.h>
#defineROW10
#defineCOL10
int**matrix;
//動態申請空間
matrix=(int**)malloc(sizeof(int*)*ROW);
for(inti=0;i<COL;i++)
{
matrix[i]=(int*)malloc(sizeof(int)*COL);
}
//賦值
for(inti=0;i<ROW;i++)
{
for(intj=0;j<COL;i++)
{
*(*(matrix+i)+j)==0;
}
}
㈨ c語言中,矩陣定義 求詳解
A, 2*2數組,初始化錯誤
B, 數組只有最右的[] 可以為空;
C, 初始化錯誤
㈩ C語言矩陣
bool FindMaxSort(int **pMatrix,int Rows,int Cols, int &MaxSort )
{
MaxSort=-200000000;
int M;
for(int i=0;i<Rows;i++)
{
if (pMatrix[i][0]>pMatrix[i][1]&&MaxSort<pMatrix[i][0]) //遞減
{
M=pMatrix[i][1];
for(int j=2;j<Cols;j++)
{
if(pMatrix[i][j]>=M) break;
M=pMatrix[i][j];
}
if (j==Cols)
{
MaxSort=pMatrix[i][0];
}
}
else if(pMatrix[i][0]<pMatrix[i][1]&&MaxSort<pMatrix[i][Cols-1]) //遞增
{
M=pMatrix[i][1];
for(int j=2;j<Cols;j++)
{
if(pMatrix[i][j]<=M) break;
M=pMatrix[i][j];
}
if (j==Cols)
{
MaxSort=pMatrix[i][Cols-1];
}
}
}
return MaxSort!=-200000000;
}