本文實(shí)例講述了Java編程實(shí)現(xiàn)的二維數(shù)組轉(zhuǎn)置功能。分享給大家供大家參考,具體如下:
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
/** * 實(shí)現(xiàn)二維數(shù)組的轉(zhuǎn)置 * @author HAN * */ public class transposition_Arrays2D_ch6_4 { final static double PI= 3.1415 ; public static void main(String[] args) { /*StaticTest st1=new StaticTest(); StaticTest st2=new StaticTest(); st1.method2("HAN");*/ /*****定義要用于轉(zhuǎn)置的二維數(shù)組*******/ int arr2D[][]={{1,2,3},{4,5,6},{7,8,9}}; /*****構(gòu)造結(jié)果新二維數(shù)組用于存放轉(zhuǎn)置結(jié)果*******/ /*定義結(jié)果數(shù)組變量,注意 一定要先開辟一個(gè)內(nèi)存, 否則只是地址傳遞,也就是說兩個(gè)數(shù)組名實(shí)際上指向的是同一塊內(nèi)存*/ //而構(gòu)造二維數(shù)組可以為維度來進(jìn)行,不一定是一個(gè)矩陣,即每一行的長(zhǎng)度不一定相同 int result_arr[][]=new int[arr2D.length][];//先實(shí)現(xiàn)第一維 for(int i=0 ; i<arr2D.length;i++){ //再實(shí)現(xiàn)第二維 result_arr[i]=new int[arr2D[i].length]; } // int result_arr[][]=Arrays.copyOf(arr2D, arr2D.length); //上面這個(gè)命令行行不通! /*****輸出用于轉(zhuǎn)置的二維數(shù)組*******/ for (int x[]:arr2D){ for(int e:x){ System.out.print(e+" "); } System.out.println(); } System.out.println(); /*******進(jìn)行元素倒置******/ for(int i=0 ; i<arr2D.length;i++){ for(int j=0; j<arr2D[i].length;j++){ result_arr[j][i]=arr2D[i][j]; //轉(zhuǎn)置核心 } } /*****show the result in the result matrix*******/ for (int x[]:result_arr){ for(int e:x){ System.out.print(e+" "); } System.out.println(); } } } //import java.util.Arrays; //public class transposition_Arrays2D { // // public static void main(String[] args) { // int arr2D[][]={{1,2,3},{4,5,6},{7,8,9}}; // /*定義結(jié)果數(shù)組變量,注意 一定要先開辟一個(gè)內(nèi)存, // 否則只是地址傳遞,也就是說兩個(gè)數(shù)組名實(shí)際上指向的是同一塊內(nèi)存*/ // int result_arr[][]=new int[arr2D.length][]; // for(int i=0 ; i<arr2D.length;i++){ // result_arr[i]=new int[arr2D[i].length]; // } // // // 進(jìn)行元素倒置 // for(int i=0 ; i<arr2D.length;i++){ // for(int j=0; j<arr2D[i].length;j++){ // result_arr[j][i]=arr2D[i][j]; // } // } // // // show the result in matrix // for (int x[]:result_arr){ // for(int e:x){ // System.out.print(e); // } // System.out.println(); // } // // } // //} |
運(yùn)行結(jié)果:
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
原文鏈接:http://blog.csdn.net/gaowen_han/article/details/7163073