将n行n列矩阵中主对角线的元素赋值为0,主对角线上方的元素赋值为-1;主对角线下方的元素赋值为1的c语言代码
时间: 2024-05-03 09:19:05 浏览: 102
以下是实现该功能的C语言代码:
```
#include <stdio.h>
#define N 100
int main() {
int n, i, j;
int a[N][N];
printf("请输入矩阵的行列数n:");
scanf("%d", &n);
// 赋值
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
if (i == j) {
a[i][j] = 0;
} else if (i < j) {
a[i][j] = -1;
} else {
a[i][j] = 1;
}
}
}
// 输出矩阵
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
printf("%d ", a[i][j]);
}
printf("\n");
}
return 0;
}
```
首先,通过 `scanf` 函数获取矩阵的行列数 `n`。然后,使用两重循环遍历矩阵的每个元素,根据元素在主对角线上方、下方或主对角线上,分别赋值为-1、1或0。最后,再次使用两重循环输出矩阵的每个元素。
相关问题
将n行n列矩阵中主对角线的元素赋值为0,主对角线上方的元素赋值为-1;主对角线下方的元素赋值为1。
可以使用两个嵌套的for循环来遍历矩阵,判断当前元素是否在主对角线上、下或者上方,下方。如果在主对角线上,则将其赋值为0;如果在主对角线上方,则将其赋值为-1;如果在主对角线下方,则将其赋值为1。具体实现代码如下:
```python
n = 5 # 矩阵的维度
matrix = [[0] * n for _ in range(n)] # 初始化矩阵
# 遍历矩阵,给主对角线及其上下方元素赋值
for i in range(n):
for j in range(n):
if i == j:
matrix[i][j] = 0 # 主对角线元素为0
elif i < j:
matrix[i][j] = -1 # 主对角线上方元素为-1
else:
matrix[i][j] = 1 # 主对角线下方元素为1
# 打印矩阵
for i in range(n):
print(matrix[i])
```
输出结果如下:
```
[0, -1, -1, -1, -1]
[1, 0, -1, -1, -1]
[1, 1, 0, -1, -1]
[1, 1, 1, 0, -1]
[1, 1, 1, 1, 0]
```
C语言将n行n列矩阵中主对角线的元素赋值为0,主对角线上方的元素赋值为-1;主对角线下方的元素赋值为1。
可以使用两个嵌套的for循环来遍历矩阵,判断当前元素是否在主对角线上、下或者上方,下方。如果在主对角线上,则将其赋值为0;如果在主对角线上方,则将其赋值为-1;如果在主对角线下方,则将其赋值为1。具体实现代码如下:
```c
#include <stdio.h>
int main() {
int n = 5; // 矩阵的维度
int matrix[n][n]; // 定义矩阵
// 遍历矩阵,给主对角线及其上下方元素赋值
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (i == j) {
matrix[i][j] = 0; // 主对角线元素为0
} else if (i < j) {
matrix[i][j] = -1; // 主对角线上方元素为-1
} else {
matrix[i][j] = 1; // 主对角线下方元素为1
}
}
}
// 打印矩阵
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
printf("%d ", matrix[i][j]);
}
printf("\n");
}
return 0;
}
```
输出结果如下:
```
0 -1 -1 -1 -1
1 0 -1 -1 -1
1 1 0 -1 -1
1 1 1 0 -1
1 1 1 1 0
```
阅读全文