在JAVA中希望所有对角线都在一个mxn矩阵中



my matrix is

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
                    }
                }
            }
        }

我已经尝试了很多次,但其他对角线没有被检查。

我能想到的一个简单的逻辑是使用两种类型的循环。第一次是向后,第二次是向前。我不太确定这是否适用于所有情况,但您可以遵循以下内容

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();
        }
    }
}

相关内容

  • 没有找到相关文章

最新更新