我对运用“或”“且”“非”不是很熟练,写代码的时候卡住了。
就是一个n×n的矩阵,例如一个6×6的矩阵:
1 2 3 4 5 6
7 8 9 10 11 12
13 14 15 16 17 18
19 20 21 22 23 24
25 26 27 28 29 30
31 32 33 34 35 36
现在要求主副对角线相交后上下两个区域内元素和两个对角线上元素的和,也就是1,2,3,4,5,6,8,9,10,11,15,16,21,22,26,27,28,29,31,32,33,34,35,36。
也就是每行主对(副)角线到副(主)对角线区域内元素的和的和。
我写了八个小时没写出来,脑细胞已经快死光了,谁能帮我写一下
#include <iostream>
const int SIZE = 6;
int main() {
int matrix[SIZE][SIZE] = {
{1, 2, 3, 4, 5, 6},
{7, 8, 9, 10, 11, 12},
{13, 14, 15, 16, 17, 18},
{19, 20, 21, 22, 23, 24},
{25, 26, 27, 28, 29, 30},
{31, 32, 33, 34, 35, 36}
};
int diagonal1_up_sum = 0;
for (int i = 0; i < SIZE; i++) {
for (int j = 0; j < SIZE; j++) {
if (i < j && (i + j) != (SIZE - 1)) {
diagonal1_up_sum += matrix[i][j];
}
}
}
std::cout << "Diagonal 1 up sum: " << diagonal1_up_sum << std::endl;
int diagonal1_down_sum = 0;
for (int i = 0; i < SIZE; i++) {
for (int j = 0; j < SIZE; j++) {
if (i > j && (i + j) != (SIZE - 1)) {
diagonal1_down_sum += matrix[i][j];
}
}
}
std::cout << "Diagonal 1 down sum: " << diagonal1_down_sum << std::endl;
return 0;
}
这是我写的,不能用