• 二维数组的倾斜遍历 java


      在操作数组的时候很多的时候都是横向和竖向遍历一个二维数组,这样的操作比较基础就不说了,但在二维数组的倾斜的遍历的方法上是多样的,这里介绍一个比较好的方法。这里是 int[][] a = new int[9][9];

     
    int[][] a = new int[9][9];
    for(int i=0;i<9;i++)
    {
    for(int j=0;j<9;j++)
    {
    a[i][j] = i;//数组赋值
    }
    }
    for(int i=0;i<9;i++)
    {
    for(int j=0;j<9;j++)
    {
    System.out.print(a[i][j]);//输出数组
    }
    System.out.println();
    }
    结果是:
    000000000
    111111111
    222222222
    333333333
    444444444
    555555555
    666666666
    777777777
    888888888
     
    倾斜遍历:
    for(int i=0;i<17;i++)
    {
    for(int j=0;j<9;j++)
    {
    if(((i-j)>=0)&&((i-j)<9))//每次倾斜的数组的下标相加的结果是一样的
    {
    System.out.print(a[j][i-j]+" ");
    }
    }
    System.out.println();
    }
    System.out.println("*******************************************");
    for(int i=-8;i<9;i++)
    {
    for(int j=0;j<9;j++)
    {
    if(((i+j)>=0)&&((i+j)<9))/每次倾斜的数组的下标相减的结果是一样的
    {
    System.out.print(a[j][i+j]+" ");
    }
    }
    System.out.println();
    }
     
    }
    结果是:
    0 1 
    0 1 2 
    0 1 2 3 
    0 1 2 3 4 
    0 1 2 3 4 5 
    0 1 2 3 4 5 6 
    0 1 2 3 4 5 6 7 
    0 1 2 3 4 5 6 7 8 
    1 2 3 4 5 6 7 8 
    2 3 4 5 6 7 8 
    3 4 5 6 7 8 
    4 5 6 7 8 
    5 6 7 8 
    6 7 8 
    7 8 
    *******************************************
    7 8 
    6 7 8 
    5 6 7 8 
    4 5 6 7 8 
    3 4 5 6 7 8 
    2 3 4 5 6 7 8 
    1 2 3 4 5 6 7 8 
    0 1 2 3 4 5 6 7 8 
    0 1 2 3 4 5 6 7 
    0 1 2 3 4 5 6 
    0 1 2 3 4 5 
    0 1 2 3 4 
    0 1 2 3 
    0 1 2 
    0 1 
  • 相关阅读:
    个人项目1修改版——自动生成四则表达式
    个人项目1——自动生成四则运算
    《面向对象分析与设计》阅读笔记3
    《面向对象分析与设计》阅读笔记2
    《面向对象分析与设计》阅读笔记1
    《梦断代码》阅读笔记3
    《梦断代码》阅读笔记2
    MVC中的过滤器
    MVC中的区域
    MVC中的路由
  • 原文地址:https://www.cnblogs.com/kong0it/p/3177010.html
Copyright © 2020-2023  润新知