重点在于: 每一列的数据的和如何来求,利用j相同,将同一列的数值加起来,并且放在对应列的最后一行。
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
# include<stdlib.h>
#include<time.h>
# define ARR_LEN 10
#define M 3
#define N 5
/*
给定一个宏定义N的值为10,声明一个长度为N的int数组,然后将数组元素初始化为它下标的平方,
最后将数组元素全部累加到一起求和,并输出打印这个和。
给定两个宏定义N的值为5,M的值是3,声明一个N * M的二维数组,然后生成伪随机数将该二维数组初始化,
要求随机数的范围在 1 到 100 之间。紧接着:
以矩阵的样式遍历打印这个二维数组中的所有元素。
求出该二维数组每一行和每一列的元素和,并输出打印结果。
第二题的运行结果如下图所示:
*/
int main(void) {
//求数组的和 初始化为下标平方
int arr[ARR_LEN]; int sum = 0;
for (int i = 0; i < ARR_LEN; i++) {
arr[i] = i * i;
sum += arr[i];
}
printf("数组平方的和是:%d\n", sum);
int arr_[N + 1][M + 1];
//先设置随机种子,在随机生成数据
srand(time(NULL));
for (int i = 0; i <= N; i++) {
for (int j = 0; j <= M; j++) {
if (i == N || j == M) {
arr_[i][j] = 0;
}
else {
arr_[i][j] = rand() % 100;
}
}
}
//输出
printf("该二维数组的元素打印效果如下:\n");
for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
if (j == 0) {
printf("%d", arr_[i][j]);
}
else {
printf(" %d", arr_[i][j]);
}
arr_[i][M] += arr_[i][j];//初始化操作 没用容易报错
arr_[N][j] += arr_[i][j];//每次j一样的值的时候
//每一行加起来,行比较容易计算,但是列想直接加起来比较麻烦
}printf("\n");
}
printf("每行的和:\n");
for (int i = 0; i < N; i++) {
printf("第 %d 行的和:%d\n", i + 1, arr_[i][M]);
}
printf("每列的和:\n");
for (int i = 0; i < M; i++) {
printf("第 %d 列的和:%d \n", i + 1, arr_[N][i]);
}
}