、构造一个4行4列的矩阵,每个元素值为行列下标的和,分别求对角线的和、上三角的和、下三角的和。
参考如下:
#include <stdio.h>
int main()
{
int a[4][4], i, j, sumA = 0, sumB = 0, sumC = 0;
for (i = 0; i < 4; i++)
{
for (j = 0; j < 4; j++)
{
a[i][j] = i + j;
if (i == j || i == 3 - j)
sumA += a[i][j]; // 对角线的和(主对角线+次对角线)
}
for (j = 0; j <= i; j++)
{
sumB += a[i][j]; // 上三角的和
}
for(j = 3; j>=i; j--)
{
sumC += a[i][j]; // 下三角的和
}
}
printf("对角线的和 = %d\n", sumA);
printf("上三角的和 = %d\n", sumB);
printf("下三角的和 = %d", sumC);
return 0;
}
题目来源:《谭浩强C语言程序设计》指针习题3
- 思路
1.编写输入输出函数。
2.编写能够找出最大值和最小值并按照:最小的与第一个交换,最大的与最后一个交换的要求进行编写。
(1)定义三个指针变量*max,*p,*min,使得开始的时候三者都指向同一个地址;
(2)先找的最大的和最小的数
(3)交换(借助中间变量temp)交换最大的与最后一个交换; 最小的与第一个交换。
3.在主函数中对三个函数分别进行调用。
- 注意事项:
如果先 最小的与第一个交换,那么如果第一个就是最大的先与最后一个交换之后,max和min指向的地址是没有变化的,但是此时最大的数的值变化了
变成了最后一个数,所以要加下面这一句:if (max == number)max = min;
代码部分如下:
temp = number[0];
number[0] = *min;
*min = temp;
if (max == number)max = min;
temp = number[9];
number[9] = *max;
*max = temp;
具体代码
// Created by acer on 2020/5/12.
//输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数
#include <stdio.h>
void output(int *number); //函数声明
void print(int *number);
void max_min(int *number);
int main() {
int number[10];
// 函数调用
print(number);
max_min(number);
output(number);
return 0;
}
void print(int *number) { //输入函数
for (int i = 0; i < 10; i++) {
scanf("%d", &number[i]);
}
}
void max_min(int *number) {
int *p, *max, *min, temp;
max = min = number;
// 1.先找的最大的和最小的
for (p = number; p < number + 10; p++) {
if (*p > *max)max = p; //把p指向地址给max,使得如果*p大于*max就让max指向p所指的数
else if (*p < *min)min = p;//把p指向地址给min,使得如果*p小于*max就让min指向p所指的数
}
// 2.交换最大的与最后一个交换
temp = number[9];
number[9] = *max;
*max = temp;
/*特殊情况:如果第一个就是最大的先与最后一个交换之后,max和min指向的地址是没有变化的,但是此时最大的数的值变化了
变成了最后一个数,所以要加下面这一句if (max == number)max = min;*/
// 最小的与第一个交换
temp = number[0];
number[0] = *min;
*min = temp;
}
void output(int *number) { //输出函数
int *p;
printf("请输入十个数字\n");
for (p = number; p < number + 10; p++) {
printf("%d", *p);
printf(" ");
}
}
结果
98 24 56 78 1 32 36 44 29 6
请输入十个数字
1 24 56 78 6 32 36 44 29 98
# 构造4行4列的矩阵
matrix = [[i+j for j in range(4)] for i in range(4)]
# 计算对角线、上三角、下三角的和
diag = 0 # 对角线和
up_tri = 0 # 上三角和
low_tri = 0 # 下三角和
for i in range(4):
for j in range(4):
if i == j:
diag += matrix[i][j]
if i < j:
up_tri += matrix[i][j]
if i > j:
low_tri += matrix[i][j]
print("构造的矩阵为:")
for i in range(4):
for j in range(4):
print(matrix[i][j], end=" ")
print()
print("对角线和为:", diag)
print("上三角和为:", up_tri)
print("下三角和为:", low_tri)
输出结果为:
构造的矩阵为:
0 1 2 3
1 2 3 4
2 3 4 5
3 4 5 6
对角线和为: 12
上三角和为: 33
下三角和为: 24