c语言输入矩阵方法:先自己输入阶数,再输入各个元素.C语言是一门面向过程、抽象化的通用程序设计语言,广泛应用于底层开发.C语言能以简易的方式编译、处理低级存储器.C语言是仅产生少量的机器语言以及不需要任何运行环境支持便能运行的高效率程序设计语言.尽管C语言提供了许多低级处理的功能,但仍然保持着跨平台的特性,以一个标准规格写出的C语言程序可在包括一些类似嵌入式处理器以及超级计算机等作业平台的许多计算机平台上进行编译.
更多关于c语言如何输入矩阵,进入:查看更多内容
#include?stdio.h
int?array[N][N];
{
int?i,j,temp;
for(i=0;iN;i++)
for(j=i+1;jN;j++)
temp=array[i][j];
array[i][j]=array[j][i];
array[j][i]=temp;
}
int?main(void)
int?i,j;
printf("请输入数据\n");
for(j=0;jN;j++)
scanf("%d",array[i][j]);
printf("\n");
transition(array);
printf("调换数据如下\n");
return?0;
~~~~~~
我写的代码,你自己参考吧,很简单的
int i,j;
scanf("%f",a[i][j]); // float 格式 %f
============
一般例子(已知数组 行列,动态分配的数组)如何传递数值:
#include stdio.h
void fun1(int *mat, int N_row, int N_col){
for (j=0;jN_row;j++){
for (i=0;iN_col;i++) printf("%d ",mat[j*N_col+i]);
for (i=0;iN_col;i++) printf("%d ",mat[j][i]);
int main()
int **a;
int NR,NC,j,i;
printf("input nrow ncol\n");
scanf("%d %d",NR,NC);
a = (int **) malloc(sizeof(int *) * NR);
for (j=0;jNR;j++){
a[j] = (int *) malloc(sizeof(int) * NC);
printf("input matrix data \n");
for (j=0;jNR;j++) for (i=0;iNC;i++) scanf("%d",a[j][i]);
return 0;
c语言矩阵分为两种:
第一种方法是动态的申请矩阵存储空间,该方法的好处有以下两点:
①能够动态的申请和释放存储空间;
第二种方法是静态存储实现,该方法的好处是简单、易实现,相对第一种方法缺点:
①静态实现,不能动态的申请和释放空间,对电脑的内容要求高;
我的代码逻辑是:
矩阵行指针初值指向每行首地址,迭代依次取所有行指针指向值组成新行,所有行指针自增.最终组合新的矩阵.
#include?malloc.h
int?**getList(int?row,int?clo);//获取矩阵地址空间
void?setNum(int?**nList,int?n);//填写数值
void?prtList(int?**nList,int?row,int?clo);//打印矩阵
int?**zz(int?**nList,int?row,int?clo);//转置函数
int?main()
int?row,clo,**nList=NULL,**nListSave=NULL;
printf("输入矩阵行列数:");
scanf("%d%d",row,clo);
nList=getList(row,clo);
setNum(nList,row*clo);
printf("输入的矩阵为:\n");
prtList(nList,row,clo);
printf("转置后的矩阵为:\n");
nListSave=zz(nList,row,clo);
free(nList);
nList=nListSave;
prtList(nList,clo,row);
int?**zz(int?**nList,int?row,int?clo)
int?*nSave=NULL,**listSave=NULL,**listp=nList,*p=NULL,i,j;
nSave=(int?*)malloc(sizeof(int)*row*clo);
listSave=(int?**)malloc(sizeof(int*)*clo);//倒置后的矩阵
p=nSave;
for(j=0;jclo;j++)
for(i=0;irow;i++)
*p++=*listp[i];
listp[i]=listp[i]+1;
for(i=0;iclo;i++)
listSave[i]=nSave[i*row];
free(nList[i]);//释放原矩阵行空间
return?listSave;
void?prtList(int?**nList,int?row,int?clo)
printf("%d?",nList[i][j]);
void?setNum(int?**nList,int?n)
int?*p=nList[0];
printf("填写矩阵中%d个数值:\n",n);
while(n--0)
scanf("%d",p++);
int?**getList(int?row,int?clo)
int?*nums,**nList,i;
nums=(int?*)malloc(sizeof(int)*row*clo);
nList=(int?**)malloc(sizeof(int*)*row);
nList[i]=nums[i*clo];
return?nList;
以上就是土嘎嘎小编为大家整理的C语言用函数输入矩阵相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!