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中数组的基本性质

  1. 数组是使用统一名称引用的一组具有相同类型的数据
  2. 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中浅拷贝和深拷贝的区别

一个例题

leetcode 1380. 矩阵中的幸运数

读者可以在此题中简单应用上述数组知识

Java一维与二维数组的拷贝与排序的更多相关文章

  1. Java中的二维数组

    Java 中的二维数组 所谓二维数组,可以简单的理解为是一种"特殊"的一维数组,它的每个数组空间中保存的是一个一维数组. 那么如何使用二维数组呢,步骤如下: 1. 声明数组并分配空 ...

  2. java学习之二维数组

    java当中的二维数组,存储一组比较特殊的对象.他存储一个数组,同时存储的数组当中又存储着元素. java二维数组的声明方式一: class Arr2Demo { public static void ...

  3. JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数

    JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数 示例如下 至少需要九个元素:"A","B","C",&q ...

  4. Java基础教程——二维数组

    二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...

  5. PHP 二维数组根据某个字段排序

    二维数组根据某个字段排序有两种办法,一种是通过sort自己写代码,一种是直接用array_multisort排序函数 一. 手写arraysort PHP的一维数组排序函数: sort  对数组的值按 ...

  6. PHP 按二维数组的键值排序

    /** * 按二维数组的键值排序 * @param unknown $array 二维数组 * @param unknown $key 二维数组的键值 * @param string $order 升 ...

  7. PHP二维数组按某个字段排序

    //准备 二维数组 //按一个字段排序 foreach($rank as $key=>$val){ $dos[$key] = $val['timelength']; } array_multis ...

  8. PHP开发小技巧②—实现二维数组根据key进行排序

    在PHP中内置了很多对数组进行处理的函数,有很多时候我们直接使用其内置函数就能达到我们的需求,得到我们所想要的结果:但是,有的时候我们却不能通过使用内置函数实现我们的要求,这就需要我们自己去编写算法来 ...

  9. 三重for循环实现对二维数组的按列排序(JavaScript)

    由C语言联想到的:三重for循环实现对二维数组的按列排序,并且牵扯到数据结构. 自己写的,水平有限,本文属于原创,可能存在错误,忘指正~ function circle() { var a = [ [ ...

随机推荐

  1. Django在使用logging日志模块时报错无法操作文件 logging error Permission Error [WinError 32]

    产生原因: 这个问题只会在开发的时候遇到,而且配置是写入到setting.py配置文件,我们定义了日志文件大小,当日志满了的时候,这时候就会遇到这个问题, 因为在使用Pycharm运行django的时 ...

  2. Selenium_浏览器窗口大小(6)

    import time from selenium import webdriver driver = webdriver.Chrome() driver.maximize_window() driv ...

  3. Flask_上下文(六)

    Flask中有两种上下文,应用上下文(application context)和请求上下文(request context) 当客户端发来请求时,请求上下文就登场了.请求上下文里包含了请求的各种信息, ...

  4. springboot 项目在idea 中不能起动,但是在eclipse中能起动

    新建的springboot 项目,在idea中用main方法起动时出现如下 : 但是把项目导入到eclispe中却能正常运行,百思不其解,网上一通百度,有的说没有依赖springboot的web 启动 ...

  5. 利用 Maven 创建 Docker 镜像并且推送到私有注册中心

    利用 Maven 命令生成项目框架 mvn archetype:generate -DgroupId=com.mycompany.app -DartifactId=my-app -Darchetype ...

  6. ES6常用知识点

    一.变量 var:定义的变量有时候会成为全局变量 let:定义的变量严格,只在代码块内有效 const:声明的变量是常量,不能被修改 二.数据类型 字符串 @定义:~字符串定义标记,支持换行.  #常 ...

  7. Git 的配置 config

    Git 的配置 config Git 的配置 config config 文件简述 config 文件位置 信息查询 修改 config 文件 编辑配置文件 增加指定配置项 删除指定配置项 自助餐   ...

  8. [源码解析] PyTorch 分布式之 ZeroRedundancyOptimizer

    [源码解析] PyTorch 分布式之 ZeroRedundancyOptimizer 目录 [源码解析] PyTorch 分布式之 ZeroRedundancyOptimizer 0x00 摘要 0 ...

  9. Cache一致性协议与伪共享问题

    Cache一致性协议 在说伪共享问题之前,有必要聊一聊什么是Cache一致性协议 局部性原理 时间局部性:如果一个信息项正在被访问,那么在近期它很可能还会被再次访问 比如循环.方法的反复调用等 空间局 ...

  10. Java 异常分析

    Java 异常分析 本文是对以下内容的分析: Java异常设计 Java 异常分类 Java异常可以告诉什么问题 Java异常处理最佳实践 Java Exception 是为了处理应用程序的异常行为而 ...