当前位置:首页 » 编程语言 » c语言求一个矩阵的最大数
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言求一个矩阵的最大数

发布时间: 2023-07-19 15:28:20

A. c语言编程求矩阵的最大值,最小值及所在的位置

#include<stdio.h>
int a[9][9]={{5,15,9,16,7,10,2,6,3,20}};

//最大值函数声明
int getmax(int *,int *);

//最小值函数声明
int getmin(int *,int *)

//主函数
void main(void)
{
int imax,jmax,imin,jmin;

printf("矩阵最大值为%d,位置为%d行,%d列;",getmax(&imax,&jmax),imax,jmax);

printf("最小值为%d,位置为%d行,%d列;",getmin(&imin,&jmin),imin,jmin);

printf("正对角线和为%d!",getlsum());

printf("反对角线和为%d!",getrsum());
}

//求最大值函数
int getmax(int * imax,int * jmax)
{
int max=0;
for(int i=0;i<9;i++)
for(int j=0;j<9;j++)
{
if(a[i][j]>max)
{
*imax=i;
*jmax=j;
max=a[i][j];
}
}
return max;
}

//求最小值函数
int getmin(int * imin,int * jmin)
{
int min=65535;
for(int i=0;i<9;i++)
for(int j=0;j<9;j++)
{
if(a[i][j]<min)
{
*imin=i;
*jmin=j;
min=a[i][j];
}
}
return min;
}

//求正对角线和函数
int getlsum()
{
int sum=0;
for(int i=0;i<9;i++)
sum+=a[i][i];
return sum
}

//求反对角线和函数
int getrsum()
{
int sum=0;
for(int i=0;i<9;i++)
sum+=a[i][9-i];
return sum;
}
程序写好了,放在一起的,公用一个主函数,如果不要显示哪个功能就把哪块干掉,如果这你都不会我就没办法了!!!

B. C语言编程:自定义一个5*5的矩阵,找出矩阵中最大的数,并输出其所在的行与列,怎么写

代码文本:

#include "stdio.h"

#define N 5

void dispmatrix(int (*p)[N]){

int i,j;

for(i=0;i<N;i++){

for(j=0;j<N;printf("%4d",p[i][j++]));

putchar(' ');

}

}

void findmax(int p[][N]){

int i,j,mi,mj;

for(mi=mj=i=0;i<N;i++)

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

if(p[mi][mj]<p[i][j])

mi=i,mj=j;

printf("The MAX is a[%d][%d]=%d ",mi,mj,p[mi][mj]);

}

int main(int argc,char *argv[]){

int a[N][N]={41,467,334,500,464,145,705,724,169,391,716,895,478,

281,961,827,995,604,163,421,358,718,382,902,491};

printf("Matrix is as follows: ");

dispmatrix(a);

printf(" ");

findmax(a);

return 0;

}

供参考。

C. 【c语言编程】矩阵求最大值或最小值并返回它所在的行号与列号

#include<stdio.h>
voidmain()
{
inti,j,minv,mini,minj,sum=0;
inta[4][4];
printf("请输入矩阵中的16个数: ");
for(i=0;i<4;i++)
for(j=0;j<4;j++)
scanf("%d",&a[i][j]);
minv=a[0][0];
for(i=0;i<4;i++)
for(j=0;j<4;j++)
{
if(a[i][j]<minv)
{
minv=a[i][j];
mini=i+1;
minj=j+1;
}
if(i==j)
sum+=a[i][j];
}
printf("矩阵中最小值为%d,它在第%d行,%d列! ",minv,mini,minj);
printf("矩阵中对角线元素之和为%d",sum);
}

你需要动态的可以这样写:

#include<stdio.h>
#include<stdlib.h>
voidmain()
{
inti,j,minv,mini=1,minj=1,sum=0,h,l;
printf("请输入矩阵的大小:");
scanf("%d%d",&h,&l);
int**a=(int**)malloc(sizeof(int*)*h);
for(i=0;i<l;i++)
a[i]=(int*)malloc(sizeof(int)*l);
printf("请输入矩阵中的%d个数: ",h*l);
for(i=0;i<h;i++)
for(j=0;j<l;j++)
scanf("%d",&a[i][j]);
minv=a[0][0];
for(i=0;i<h;i++)
for(j=0;j<l;j++)
{
if(a[i][j]<minv)
{
minv=a[i][j];
mini=i+1;
minj=j+1;
}
}
printf("矩阵中最小值为%d,它在第%d行,%d列! ",minv,mini,minj);
minv=a[0][0];
for(i=0;i<h;i++)
for(j=0;j<l;j++)
{
if(a[i][j]>minv)
{
minv=a[i][j];
mini=i+1;
minj=j+1;
}
}
printf("矩阵中最大值为%d,它在第%d行,%d列! ",minv,mini,minj);
}

D. C语言编程:输入一个M*N的整数矩阵,求其最大值及其所在的行号、列号。(M、N由键盘输入)

#include<stdio.h>
#include<stdlib.h>
int main()
{
int i,m,n,*array;
printf("请输入矩阵行数:");
scanf("%d",&m);
printf("请输入矩阵列数:");
scanf("%d",&n);
array=(int*)malloc(m*n*sizeof(int));
printf("请输入该%d*%d矩阵:\n",m,n);
for(i=0;i<m*n;i++)
scanf("%d",&array[i]);
int max=array[0];
int index=0;
for(i=1;i<m*n;i++)
{
if(max<array[i])
{
max=array[i];
index=i;
}
}
printf("您输入的矩阵中的最大值为:%d\n",max);
printf("它所在的行号和列号分别是:%d,%d\n",(index/n)+1,(index%n)+1);
return 0;
}

E. C语言矩阵的最大值

#define ROW 3
#define COL 4
int main()
{
/*定义一个矩阵*/
int a[ROW][COL];
int i=0;
int j=0;
int maxValue=0;

/*矩阵赋值*/
for (i=0;i<ROW;i++)
{
for (j=0;j<COL;j++)
{
printf("请输入%i行%d列的值:",i+1,j+1);
scanf("%d",&a[i][j]);
}
}
maxValue = a[0][0];

for (i=0;i<ROW;i++)
{
for (j=0;j<COL;j++)
{
if (maxValue<a[i][j])
{
maxValue=a[i][j];
}
}
}

printf("矩阵的最大值是:%d\n",maxValue);

return 0;
}