Java一维与二维数组的拷贝与排序
Java一维与二维数组的拷贝与排序
Arrays.sort()
一维数组升序排序
e.g.(demo.java)
import java.util.Arrays;
public class demo {
public static void main(String[] args){
int[] arr = new int[]{1,5,98,6,78,65};
Arrays.sort(arr);
for(int i : arr){
System.out.println(i);
}
}
output:
1
5
6
65
78
98
二维数组按行升序排序
e.g.(demo.java)
import java.util.Arrays;
public class demo {
public static void main(String[] args){
int [][] arr = new int[][]{{1,20,3},{20,3,5},{9,0,8}};
int n = arr.length;
for(int i = 0;i < n;i++){
Arrays.sort(arr[i]);
}
for(int i = 0;i < n;i++){
for(int j : arr[i]){
System.out.print(j + " ");
}
System.out.println();
}
}
output:
1 3 20
3 5 20
0 8 9
二维数组按列升序排序
思路:将数组转置,每行调用Arrays.sort(),再转置回来
e.g.(demo.java)
import java.util.Arrays;
public class demo {
public static int[][] arrTransfer(int[][] arr){ //借用线代思想,对矩阵转置
int n = arr.length;
int m = arr[0].length;
int[][] ret = new int[m][n];
for(int i = 0;i < n;i++){
for(int j = 0;j < m;j++){
ret[j][i] = arr[i][j];
}
}
return ret;
}
public static void main(String[] args){
int [][] arr = new int[][]{{1,20,3},{20,3,5},{9,0,8}};
int n = arr.length;
int m = arr[0].length;//该方法适用于矩阵类二维数组,不等长二维数组不适用
int[][] tempArr = new int[m][n];
tempArr = arrTransfer(arr);
for(int i = 0;i < m;i++){
Arrays.sort(tempArr[i]);
}
arr = arrTransfer(tempArr);
for(int i = 0;i < n;i++){
for(int j : arr[i]){
System.out.print(j + " ");
}
System.out.println();
}
}
output:
1 0 3
9 3 5
20 20 8
Java中的数组
Java中数组的基本性质
- 数组是使用统一名称引用的一组具有相同类型的数据
- Java中的数组属于引用类型(对象),类似C语言中的指针
一维数组的拷贝
e.g.(demo.java)
import java.util.Arrays;
public class demo {
public static void main(String[] args){
int[] arr1 = {10,2,5,4};
int[] arr2 = arr1.clone(); //获得arr1的一份拷贝,arr2指向的内存空间不同于arr1
int[] arr3 = arr1; //获得了arr1(引用)的拷贝,赋给arr3,二者同时指向一块内存空间,因此对arr3或arr1做的操作都会反映到同一块内存空间上
Arrays.sort(arr1);
System.out.println("arr1" + Arrays.toString(arr1));
System.out.println("arr2" + Arrays.toString(arr2));
System.out.println("arr3" + Arrays.toString(arr3));
}
}
二维数组的拷贝
二维数组可以看作数组的数组,即,每一个元素都是一个一维数组,因此可以依照上述拷贝一维数组的思想拷贝二维数组
e.g.(demo.java)
import java.util.Arrays;
public class demo {
public static void main(String[] args){
int[][] arr1 = {{1,20,4},{23,92,24},{92,482,234}};
int[][] arr2 = arr1.clone();
int n = arr1.length;
int m = arr1[0].length;
int[][] arr3 = new int[n][m];
for(int i = 0;i < n;i++){
arr3[i] = arr1[i].clone();
}
for(int i = 0;i < n;i++){
Arrays.sort(arr1[i]);
}
System.out.println("arr1" + Arrays.toString(arr1));
System.out.println("arr2" + Arrays.toString(arr2));
System.out.println("arr3" + Arrays.toString(arr3));
for(int i = 0;i < n;i++){
System.out.println("arr1" + Arrays.toString(arr1[i]));
}
for(int i = 0;i < n;i++){
System.out.println("arr2" + Arrays.toString(arr2[i]));
}
for(int i = 0;i < n;i++){
System.out.println("arr3" + Arrays.toString(arr3[i]));
}
}
}
output:
arr1[[I@4eec7777, [I@3b07d329, [I@41629346]
arr2[[I@4eec7777, [I@3b07d329, [I@41629346]
arr3[[I@214c265e, [I@448139f0, [I@7cca494b]
arr1[1, 4, 20]
arr1[23, 24, 92]
arr1[92, 234, 482]
arr2[1, 4, 20]
arr2[23, 24, 92]
arr2[92, 234, 482]
arr3[1, 20, 4]
arr3[23, 92, 24]
arr3[92, 482, 234]
从输出可以看出,arr2和arr1值相等,指向同一块内存空间;arr3复制arr1的数据到另一块内存空间,不受arr1引用的内存空间的数据的改变影响;同时可以看出,arr1是一个特殊的数组,每个元素是一个一维数组
关于浅拷贝与深拷贝
上述的拷贝仅仅局限于数组,事实上对象等也可以拷贝,此处涉及深浅拷贝的区别,读者可以参考以下两篇博客:
一个例题
读者可以在此题中简单应用上述数组知识
Java一维与二维数组的拷贝与排序的更多相关文章
- Java中的二维数组
Java 中的二维数组 所谓二维数组,可以简单的理解为是一种"特殊"的一维数组,它的每个数组空间中保存的是一个一维数组. 那么如何使用二维数组呢,步骤如下: 1. 声明数组并分配空 ...
- java学习之二维数组
java当中的二维数组,存储一组比较特殊的对象.他存储一个数组,同时存储的数组当中又存储着元素. java二维数组的声明方式一: class Arr2Demo { public static void ...
- JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数
JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数 示例如下 至少需要九个元素:"A","B","C",&q ...
- Java基础教程——二维数组
二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...
- PHP 二维数组根据某个字段排序
二维数组根据某个字段排序有两种办法,一种是通过sort自己写代码,一种是直接用array_multisort排序函数 一. 手写arraysort PHP的一维数组排序函数: sort 对数组的值按 ...
- PHP 按二维数组的键值排序
/** * 按二维数组的键值排序 * @param unknown $array 二维数组 * @param unknown $key 二维数组的键值 * @param string $order 升 ...
- PHP二维数组按某个字段排序
//准备 二维数组 //按一个字段排序 foreach($rank as $key=>$val){ $dos[$key] = $val['timelength']; } array_multis ...
- PHP开发小技巧②—实现二维数组根据key进行排序
在PHP中内置了很多对数组进行处理的函数,有很多时候我们直接使用其内置函数就能达到我们的需求,得到我们所想要的结果:但是,有的时候我们却不能通过使用内置函数实现我们的要求,这就需要我们自己去编写算法来 ...
- 三重for循环实现对二维数组的按列排序(JavaScript)
由C语言联想到的:三重for循环实现对二维数组的按列排序,并且牵扯到数据结构. 自己写的,水平有限,本文属于原创,可能存在错误,忘指正~ function circle() { var a = [ [ ...
随机推荐
- react中使用react-transition-group(CSSTransition)
https://blog.csdn.net/sophie_u/article/details/80093876
- Spark-2.0.2源码编译
注:图片如果损坏,点击文章链接:https://www.toutiao.com/i6813925210731840013/ Spark官网下载地址: http://spark.apache.org/d ...
- [转]webpack——CommonsChunkPlugin
作用虽然webpack4已经出来很久了,CommonsChunkPlugin也已经舍弃了,但是还是有很多项目是通过webpack3来打包的,对CommonsChunkPlugin各个配置项的认识还是比 ...
- 关于Java注释报错的一个问题
做作业时发现一个问题,注释会报错 主要代码如下: String str = "C:\\users\\Default.migrated"; str += "\\HelloW ...
- css上下居中
position: absolute; top: 20%; left: 50%; transform: translateX(-50%); -ms-transform: translateX(-50% ...
- 展示html/javascript/css------Live-Server服务器
Live-server简介 这是一款带有热加载功能的小型开发服务器.用它来展示你的HTML / JavaScript / CSS,但不能用于部署最终的网站. 官网地址:https://www.npmj ...
- HTTP协议层面绕过WAF
最近也是在一直看过waf相关的资料,本次主要是想写写HTTP协议层面过WAF的一些技巧,来与大家一同探讨 原理 给服务器发送payload数据包,使得waf无法识别出payload,当apache,t ...
- 从AAB文件生成APK文件
开头先说方法 1.下载 bundletool 2.开始生成 java -jar bundletool.jar build-apks --bundle=[aab文件路径(例如:C:\Users\Admi ...
- JUC并发编程与高性能内存队列disruptor实战-上
JUC并发实战 Synchonized与Lock 区别 Synchronized是Java的关键字,由JVM层面实现的,Lock是一个接口,有实现类,由JDK实现. Synchronized无法获取锁 ...
- tmux安装配置与使用
tmux安装 sudo apt-get install tmux tmux配置 在家目录下操作 cd git clone https://github.com/gpakosz/.tmux.git ln ...