本文实例讲述了Java编程实现的二维数组转置功能。分享给大家供大家参考,具体如下:
/** * 实现二维数组的转置 * @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");*/ /*****定义要用于转置的二维数组*******/ int arr2D[][]={{1,2,3},{4,5,6},{7,8,9}}; /*****构造结果新二维数组用于存放转置结果*******/ /*定义结果数组变量,注意 一定要先开辟一个内存, 否则只是地址传递,也就是说两个数组名实际上指向的是同一块内存*/ //而构造二维数组可以为维度来进行,不一定是一个矩阵,即每一行的长度不一定相同 int result_arr[][]=new int[arr2D.length][];//先实现第一维 for(int i=0 ; i<arr2D.length;i++){ //再实现第二维 result_arr[i]=new int[arr2D[i].length]; } // int result_arr[][]=Arrays.copyOf(arr2D,arr2D.length); //上面这个命令行行不通! /*****输出用于转置的二维数组*******/ for (int x[]:arr2D){ for(int e:x){ System.out.print(e+" "); } System.out.println(); } System.out.println(); /*******进行元素倒置******/ 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 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,9}}; // /*定义结果数组变量,注意 一定要先开辟一个内存, // 否则只是地址传递,也就是说两个数组名实际上指向的是同一块内存*/ // int result_arr[][]=new int[arr2D.length][]; // for(int i=0 ; i<arr2D.length;i++){ // result_arr[i]=new int[arr2D[i].length]; // } // // // 进行元素倒置 // 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(); // } // // } // //}
运行结果:
更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。
您可能感兴趣的文章:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。