我的矩阵是
0 1 2 3 4
5 6 7 8 9
10 11 12 12 14
15 16 17 18 19
我想打印
4
3 9
2 8 14
1 7 12 19
0 6 12 18
5 11 17
10 16
15
提前致谢。此代码正在检查其他对角线
目前的代码是:
int rows = 5;
int cols = 8;
int maxSum = rows + cols - 2;
for (int sum = 0; sum <= maxSum; sum++) {
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
if (i + j - sum == 0) {
// work is done here
}
}
}
}
我已经尝试了很多,但其他对角线没有得到检查。
答案 0 :(得分:1)
我能想到的一个简单逻辑是使用两种类型的循环。首先是向后方向,第二种是向前方向。我不太确定这是否适用于所有情况,但你可以遵循这样的事情
public class MatrixDiagonal {
public static void main(String[] args) {
int m = 4, n = 5;
int[][] matrix = { { 0, 1, 2, 3, 4 },
{ 5, 6, 7, 8, 9 },
{ 10, 11, 12, 12, 14 },
{ 15, 16, 17, 18, 19 } };
for(int j=n-1; j>=0; j--){
for(int k=0; k<m; k++){
if((j + k) < n){
System.out.print(matrix[k][j + k] + " ");
} else {
break;
}
}
System.out.println();
}
for(int i=1; i<m; i++){
for(int j=i, k=0; j<m && k<n; j++, k++){
System.out.print(matrix[j][k] + " ");
}
System.out.println();
}
}
}