Java编程实现的二维数组转置功能示例
发布时间:2020-12-14 20:04:35  所属栏目:Java  来源:网络整理 
            导读:本篇章节讲解Java编程实现的二维数组转置功能。供大家参考研究具体如下: /** * 实现二维数组的转置 * @author HAN * */public class transposition_Arrays2D_ch6_4 { final static double PI=3.1415; public static void main(String[] args) { /
                
                
                
            | 本篇章节讲解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程序设计有所帮助。 您可能感兴趣的文章:
 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! | 

