java 二维数组排序

java 二维数组排序①使用Comparator生成一个比较器对象初始化数组:int[][]arr=newint[m][n];排序规则:先按数组的第一个元素进行升序排序,若第一个元素相等,则按照第二个元素进行升序排序。使用API:Arrays.sort()(T[]a,Comparator<?superT>c),该API根据给定的比较器(设定排序方式)对指定的数组进行排序。代码实现:Arrays.sort(arr,newComparator<int[]>(){

大家好,又见面了,我是你们的朋友全栈君。

二维数组排序

① 实现Comparator接口 :匿名内部类实现

初始化数组int [][]arr = new int [n][2];

排序规则: 对于n行两列的元素,先按数组的第一列进行升序排序,若某两行第一列相等,则按照第二列进一步排序。

使用APIArrays.sort()(T[] a, Comparator<? super T> c),该API根据给定的比较器对指定的数组进行排序。

compare 方法和sort 方法:compare方法返回int型数据,如果返回值大于0,表示需要交换两个元素;返回值小于0表示顺序正确;返回值等于0表示两个数相等。

代码实现

Arrays.sort(arr, new Comparator<int[]>() { 
       // 匿名内部类
	@Override
	public int compare(int[] e1, int[] e2) { 
   
		// 如果第一列元素相等,则比较第二列元素
		if (e1[0]==e2[0]) return e1[1]-e2[1];   // e1[1]-e2[1]表示对于第二列元素进行升序排序
		return e1[0]-e2[0];                     // e1[0]-e2[0]表示对于第一列元素进行升序排序
	}
});

② lambda表达式实现

法①使用匿名内部类实现comparator接口,同样也可以使用lambda表达式实现,代码如下:

// 仅按第一列元素升序排序
Arrays.sort(arr, (e1, e2) -> (e1[0] - e2[0]));   // "->"lambda表达式符号,其将参数与实现隔开。
// 先按第一列元素升序排序,如果第一列相等再按第二列元素升序;
Arrays.sort(arr, (e1,e2)->(e1[0]==e2[0]?(e1[1]-e2[1]):(e1[0]-e2[0])));

二维数组翻转90度

  1. 介绍:将给定二维数组翻转90度

  2. 示例:[[1,2,3],[4,5,6],[7,8,9]]] -> [[7,4,1],[8,5,2],[9,6,3]]
    算法(空间复杂度为常数):
    ①:首先按照对角线进行交换,然后上下交换;

    int[][] matrix = new int[][]{ 
         { 
         1,2,3}, { 
         4,5,6}, { 
         7,8,9}};
    int len = matrix.length;
    // 按主对角线交换
    for (int i = 0; i < len; i++) { 
         
        for (int j = 0; j < len - i; j++) { 
         
            int temp = matrix[i][j];
            matrix[i][j] = matrix[len-j-1][len-i-1];
            matrix[len-j-1][len-i-1] = temp;
        }
    }
    //上下翻转
    for (int i = 0; i < len/2; i++) { 
         
        for (int j = 0; j < len; j++) { 
         
            int temp = matrix[i][j];
            matrix[i][j] = matrix[len-i-1][j];
            matrix[len-i-1][j] = temp;
        }
    }
    // 翻转后:
    for (int[] ints : matrix) { 
         
        for (int num : ints) { 
         
            System.out.print(num + " ");
        }
        System.out.println();
    }
    

    ②:按照斜对角线交换,然后左右交换;

    //斜对角线翻转
    for(int i = 0; i < len; i ++){ 
         
        for(int j = i; j < len; j ++){ 
         
            int temp = matrix[i][j];
            matrix[i][j] = matrix[j][i];
            matrix[j][i] = temp;
        }
    }
    //左右翻转
    for(int i = 0; i < len; i ++){ 
         
        for(int j = 0; j < len/2; j ++){ 
         
            int temp = matrix[i][j];
            matrix[i][j] = matrix[i][len-j-1];
            matrix[i][len-j-1] = temp;
        }
    }
    
    // 翻转后:
    for (int[] ints : matrix) { 
         
        for (int num : ints) { 
         
            System.out.print(num + " ");
        }
        System.out.println();
    }
    

参考

https://www.apiref.com/java13/java.base/java/util/Arrays.html#sort(T[],java.util.Comparator)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135204.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • php 开启opcode,php 开启 opcode 测试

    php 开启opcode,php 开启 opcode 测试php 开启 opcode 测试 合理使用 实验环境系统信息 Linuxlocalho localdomain3 10 0 514 10 2 el7 x86 64 1SMPFriMar30 04 05UTC2017x86 64×86 64×86 64GNU Linux 内存 512MCPU1 核 PHP 版本 PHP7 0 21 amp ZendOPcach

    2025年7月3日
    4
  • pycharm滚动放大缩小字体_pycharm滚轮调整字体大小

    pycharm滚动放大缩小字体_pycharm滚轮调整字体大小pycharm中,设置滚轮直接调整字体大小步骤1、setting2、Editor→General3、勾选Change。。。。。。。4、Apply5、OK

    2022年8月27日
    3
  • PKI

    PKI

    2021年7月27日
    63
  • 大数据分析应用的机遇与挑战「建议收藏」

    大数据分析应用的机遇与挑战「建议收藏」随着信息技能的发展,互联网家当的进步,计算机数据处理能力的快速增长,电子商务的日新月异及各种社交媒体的传播扩散,各种信息无时无刻不在影响着我们的生活。我们每时每刻都在自觉或者不自觉得与数据打交道,成为数据的记录者与传播者。海量数据的处理,以及如何利用大数据营销,给我们提出了更多的挑战。在这个人人都高喊“大数据时代”的今天,数据似乎被提到一个前所未有的高度。无论是个人还是企业,无论是网络营销还是线…

    2022年5月15日
    40
  • mybatis-plus 在线激活码_在线激活

    (mybatis-plus 在线激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月26日
    244
  • Django自动化运维管理平台

    Django自动化运维管理平台运维管理平台展示,还在完善中,有所不足,望提出建议,感激不尽。@@个人网站:http://www.mykurol.com@@ Github:https://github.com/kurolz  架构:Python+Django+bootstrap+SaltStack+Zabbix+MySQL  资产管理:采用SaltStack调用收集主机配置信息入库  自动添加主机:输入ip、s…

    2022年5月17日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号