C语言 有一个n×n的矩阵,求两个对角线元素的和
时间: 2024-05-14 13:18:50 浏览: 108
可以使用如下的C语言代码来求解:
```c
#include <stdio.h>
int main() {
int n, i, j, sum1 = 0, sum2 = 0;
printf("请输入矩阵的大小n:");
scanf("%d", &n);
int a[n][n];
// 读入矩阵元素
printf("请输入矩阵中的元素:\n");
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
scanf("%d", &a[i][j]);
}
}
// 求对角线元素的和
for (i = 0; i < n; i++) {
sum1 += a[i][i];
sum2 += a[i][n-i-1];
}
printf("矩阵对角线元素的和为:%d和%d\n", sum1, sum2);
return 0;
}
```
首先,我们需要输入矩阵的大小n,并创建一个二维数组a来存储矩阵元素。然后,我们通过两个循环读入矩阵元素。
接下来,我们使用两个循环分别累加主对角线和副对角线上的元素值。主对角线上的元素坐标为a[i][i],而副对角线上的元素坐标为a[i][n-i-1],其中n-i-1是副对角线上元素的列坐标。
最后,输出两个对角线元素的和即可。
相关问题
用c语言代码实现求一个n×n矩阵的两个对角线元素的和
以下是用C语言代码实现求一个n×n矩阵的两个对角线元素的和:
```c
#include <stdio.h>
int main() {
int n, i, j, sum1 = 0, sum2 = 0;
printf("请输入矩阵的维数n:");
scanf("%d", &n);
int a[n][n]; // 定义矩阵
printf("请输入矩阵的元素:\n");
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
scanf("%d", &a[i][j]); // 读入矩阵元素
}
}
for (i = 0; i < n; i++) {
sum1 += a[i][i]; // 求主对角线元素的和
sum2 += a[i][n - 1 - i]; // 求副对角线元素的和
}
printf("主对角线元素的和为:%d\n", sum1);
printf("副对角线元素的和为:%d\n", sum2);
return 0;
}
```
程序运行时,先输入矩阵的维数n,然后输入矩阵的元素,最后输出主对角线元素的和和副对角线元素的和。
C语言求n*n矩阵对角线元素之和
以下是两种C语言求n*n矩阵对角线元素之和的例子:
1.使用二维数组
```c
#include <stdio.h>
int main() {
int a[10][10]; //定义n*n的二维数组
int i, sum = 0, n; //i作为循环标号,sum用来求和;n就是我们要输入的n*n矩阵。
printf("input n 形成n*n矩阵\n");
scanf("%d", &n);
printf("\n");
//下面两个嵌套的for循环就是来初始化(赋值)数组。
for (i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
scanf("%d", &a[i][j]);
}
}
//因为n是我们输入的数,无法确定几个元素相加,就要使用循环解决。
for (i = 0; i < n; i++) {
sum += a[i][i]; //因为是相加对角线上的元素,所以该元素就是第n行,第n列。
}
printf("sum=%d", sum);
return 0;
}
```
2.使用条件判断
```c
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define N 5
int main() {
int score[N][N], i, j, sum = 0;
srand(time(NULL));
for (i = 0; i < N; i++) {
for (j = 0; j < N; j++) {
score[i][j] = rand() % 10 + 1;
}
}
for (i = 0; i < N; i++) {
for (j = 0; j < N; j++) {
if (i == j || j + i == N - 1) {
sum = sum + score[i][j];
}
printf("%-4d", score[i][j]);
}
printf("\n");
}
printf("%d\n", sum);
return 0;
}
```
阅读全文