黑马程序员技术交流社区

标题: 求教 二维数组编程题,大神看过来吧 [打印本页]

作者: 刘小白    时间: 2016-8-1 16:06
标题: 求教 二维数组编程题,大神看过来吧
本帖最后由 刘小白 于 2016-8-1 18:36 编辑

[size=18.6667px]用二维数组打印出下面的4种情况
题目一 : 上三角
1 2 3 4 5
0 6 789
0 0 10 11 12
0 0 0 13 14
0 0 0 0 15
题目二: 下三角

1
0
0
0
0
2
6
0
0
0
3
7
10
0
0
4
8
11
13
0
5
9
12
14
15
题目三 : 对称三角
1
2
3
4
5
2
6
7
8
9
3
7
10
11
12
4
8
11
13
14
5
9
12
14
15
题目四: 斜三角
1 0 0 0 0
6 2 0 0 0
10 7 3 0 0
13 11 8 4 0
15 14 12 9 5


作者: suncool    时间: 2016-8-1 18:06
for (int i=0;i<=5;i++){
                        for (int j=5;j>=i;j--){
                        System.out.print("*");
                }
                        System.out.println("");
               
                }
作者: suncool    时间: 2016-8-1 18:08
三角
                for (int i=0;i<=5;i++){
                        for (int j=1;j<=i;j++){
                        System.out.print("*");//外循环
                }
                        System.out.println("");//内
               
                }
作者: 刘小白    时间: 2016-8-1 18:32
suncool 发表于 2016-8-1 18:08
三角
                for (int i=0;i

额,兄弟我说的是二维数组
作者: caolufo    时间: 2016-8-2 00:42
是那种情形呢?
情形一:是按照你给的二维数组,把数值直接存进去,然后遍历(这样还是简单)
情形二:是按照数值递增的模式给二维数组赋值,然后遍历(这就有难度了)

作者: 乐仔其中    时间: 2016-8-2 00:53
public class Array_TriangleTest{
    public static void main(String[] args){
        //上三角演示
        int[][] arr1 = new int[5][5];   
        UpTriangle(arr1);
        arrayPrint(arr1);
        //下三角演示
        int[][] arr2 = new int[5][5];
        downTriangle(arr2);
        arrayPrint(arr2);
        //对称三角演示
        int[][] arr3 = new int[5][5];
        UpTriangle(arr3);
        downTriangle(arr3);
        arrayPrint(arr3);
    }
    //构造上三角
    private static void UpTriangle(int[][] arr){
        
        int i=1;
        for(int y=0;y<5;y++){
            for (int x=0;x<5;x++){
                if(x>=y){
                    arr[x][y] = i;   
                    i+=1;
                }
               
            }
        }
    }
    //构造下三角
        private static void downTriangle(int[][] arr){
        
        int i=1;
        for(int x=0;x<5;x++){
            
            for (int y=0;y<5;y++){
                if(y>=x){
                    arr[x][y] = i;        
                    i+=1;
                }
               
            }
        }
    }

    //打印三角
    private static void arrayPrint(int[][] arr){
        for (int y = 0;y<5;y++){
            for(int x = 0;x<5;x++){
                System.out.print(arr[x][y]+"\t");
            }
            System.out.println("\n");
        }
        System.out.println("------------------------------------");
    }
   
}


作者: 刘小白    时间: 2016-8-2 10:00
乐仔其中 发表于 2016-8-2 00:53
public class Array_TriangleTest{
    public static void main(String[] args){
        //上三角演示

谢谢啦,还有对称三角和斜三角嘞?
作者: suncool    时间: 2016-8-2 17:09
刘小白 发表于 2016-8-1 18:32
额,兄弟我说的是二维数组

弄错少了。看错题目了哈哈
作者: 刘小白    时间: 2016-8-2 17:41
suncool 发表于 2016-8-2 17:09
弄错少了。看错题目了哈哈

对称三角还没整明白呢 阿西
作者: 刘小白    时间: 2016-8-2 17:42
caolufo 发表于 2016-8-2 00:42
是那种情形呢?
情形一:是按照你给的二维数组,把数值直接存进去,然后遍历(这样还是简单)
情形二:是按 ...

第二种情形的,兄弟
作者: caolufo    时间: 2016-8-2 18:25
本帖最后由 caolufo 于 2016-8-2 18:28 编辑

一、 在6楼的基础上补充斜三角
//斜三角
        private static void xieTriangle(int[][] arr){
            int i=1;
            for (int k=0;k<5;k++){   //控制5次沿斜向赋值
              for(int x=0,y=0;x<5-k;x++,y++){   //每一次外循环赋值元素个数减一;沿斜线变化,2个索引同时++运算
                        arr[x][y+k] = i;     
                        i++;
              }   
            }
        }
二、6楼给的答案有对称三角(注意arr3):思路是上下三角各执行遍,即为所有元素赋值。
另一种思路是,执行一边上三角或下三角,利用对称给其他元素赋值,a【x】【y】=a【y】【x】。
作者: 刘小白    时间: 2016-8-2 18:30
caolufo 发表于 2016-8-2 18:25
一、 在6楼的基础上补充斜三角:
//斜三角
        private static void xieTriangle(int[][] arr){

谢了兄弟
作者: 乐仔其中    时间: 2016-8-2 21:43
刘小白 发表于 2016-8-2 10:00
谢谢啦,还有对称三角和斜三角嘞?

我想着,对称三角就是上三角和下三角构造的组合。斜三角还没想出来,看看大家有谁会的,一起学习。
作者: 乐仔其中    时间: 2016-8-2 21:44
刘小白 发表于 2016-8-2 10:00
谢谢啦,还有对称三角和斜三角嘞?

我想着,对称三角就是上三角和下三角构造的组合。斜三角昨天没想出来。。
作者: 乐仔其中    时间: 2016-8-2 21:46
刘小白 发表于 2016-8-2 10:00
谢谢啦,还有对称三角和斜三角嘞?

我想着,对称三角就是上三角和下三角构造的组合。斜三角昨天没想出来。。
作者: 刘小白    时间: 2016-8-2 22:24
乐仔其中 发表于 2016-8-2 21:43
我想着,对称三角就是上三角和下三角构造的组合。斜三角还没想出来,看看大家有谁会的,一起学习。 ...

[Java] 纯文本查看 复制代码
public static void main(String[] args) {
                int[][] arr = new int[5][5];
                int num = 1;
                // 控制5次沿斜向赋值
                for (int k = 0; k < 5; k++) {
                        // 每一次外循环赋值元素个数减一;沿斜线变化,2个索引同时++运算
                        for (int x = 0, y = 0; x < 5 - k; x++, y++) {
                                arr[y + k][x] = num;
                                num++;
                        }
                }
                for (int j = 0; j < arr.length; j++) {
                        for (int i = 0; i < arr.length; i++) {
                                System.out.print(arr[j] + " ");
                        }
                        System.out.println();
                }
        }


这个是斜三角,刚弄出来
作者: 乐仔其中    时间: 2016-8-2 22:27
刘小白 发表于 2016-8-2 22:24
[mw_shl_code=java,true]public static void main(String[] args) {
                int[][] arr = new int[5][5];
                i ...

我看到了,我们共同学习。谢谢




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2