原题链接:对称矩阵
解题思路:
①:为二维数组开辟空间
②:输入矩阵
③:判断矩阵是否为对称矩阵
1):设四阶矩阵
1 2 3 4
2 3 3 4
3 3 5 6
4 4 6 7
2):对称矩阵主对角线两边的元素关于主对角线对称
3):遍历的时候,仅遍历主对角线上方的元素或者下方的元素
4):以上方为例:每一行的主对角线元素的后面的元素都是主对角线上方的元素
5):所以遍历每一行时从主对角线元素后方开始遍历即可
④:释放空间
参考代码:
#include<stdio.h>
#include<malloc.h>
double ** Malloc_(int n);
void free_space(double **a,int n);
void input_number(double **a,int n);
void judge_(double **a,int n);
int main()
{
int n;
double **a;
while(scanf("%d",&n)!=EOF)
{
a=Malloc_(n);/*动态分配二维数组*/
input_number(a,n);/*输入矩阵*/
judge_(a,n);/*判断是否为对称矩阵*/
free_space(a,n);/*释放空间*/
}
return 0;
}
/*===============================================*/
double ** Malloc_(int n)
{
double **a=(double **)malloc(n*sizeof(double *));/*为二维数组分配n行*/
for(int i=0;i<n;i++)
{
a[i]=(double *)malloc(n*sizeof(double));/*为每行分配大小为n的空间*/
}
return a;
}
/*===============================================*/
void free_space(double **a,int n)
{
for(int i=0;i<n;i++)
free(a[i]);/*释放每一行*/
free(a);/*释放存放每一行的地址的空间*/
}
/*===============================================*/
void input_number(double **a,int n)
{
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
scanf("%lf",&a[i][j]);
}
/*===============================================*/
void judge_(double **a,int n)
{
int term=1;
for(int i=0;i<n;i++)
for(int j=i+1;j<n;j++)
{
if(a[i][j]!=a[j][i])
{term=0;break;}
}
if(term==1)
printf("Yes!\n");
else
printf("No!\n");
}别忘点赞哦-.-
0.0分
3 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复