c语言中创建矩阵函数 c语言怎么做矩阵

c语言编程问题:矩阵的建立与运算

你这是求助还是出题考别人呀?

站在用户的角度思考问题,与客户深入沟通,找到温岭网站设计与温岭网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、成都做网站、企业官网、英文网站、手机端网站、网站推广、域名注册雅安服务器托管、企业邮箱。业务覆盖温岭地区。

回答者:starway1982 - 试用期 一级

就是,问问题要谦虚

怎样用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语言,矩阵

上面那个程序是我写的,下面写的是两个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;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;

//动态建立一个矩阵空间以存放运算结果

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

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

{

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

}

//计算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;

//动态建立一个矩阵空间以存放运算结果

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

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

{

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

}

//计算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; //行数和列数在此更改

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;irow;i++)

{

printf("\n");

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

{

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

}

}

//调用函数,求两矩阵的积

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]);

}

}

}

本来程序还可以写得简单一些,由于你要求两矩阵同时能够相加和相乘,从而可以判定两矩阵的行数和列数应该是相等的,因而在函数传递参数的时候只要传一个就行了。但是考虑到程序的可移植性,我在写相加和相乘的子函数时,考虑了普遍性,即对于给定的任意的row和col(甚至row != col),加法和乘法都能够适用。然而这样一来,形参看起来就比较多了。你自己就情况而定吧,不懂的地方发我消息。

C语言中如何定义矩阵?

两种方式可以参考:

1、最简单的就是二维数组,比如存储全是整形的一个m*n的矩阵。然后可以定义int a[m][n]。

输入或者输出可以用两层循环来完成,外层控制行m比如for(i=0;im;++i),内层控制列n比如for(j=0;jn;++j);

2、第二种方式就是压缩矩阵进行存储,如果学了数据结构应该比较好理解。

结构体进行封装,比如:

第一步:先定义一个有效数据的位置

typedef struct node

{

int hang;int lie;int data;//用来存储一个有效数据位的行列和值

}node;

typedef struct matrix

{

node *m;//一个数组,用来存储所有的node数据

int sum;//记录一共有多少个有效数据位

}matrix;

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;

}


当前名称:c语言中创建矩阵函数 c语言怎么做矩阵
文章URL:http://myzitong.com/article/hphpjh.html