go语言LeetCode题解1030距离顺序排列矩阵单元格

 更新时间:2022年12月28日 09:41:23   作者:刘09k11  
这篇文章主要为大家介绍了go语言LeetCode题解1030距离顺序排列矩阵单元格,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一 描述

1030. 距离顺序排列矩阵单元格 - 力扣(LeetCode) (leetcode-cn.com)

给定四个整数 row ,   colsrCentercCenter 。有一个 rows x cols 的矩阵,你在单元格上的坐标是 (rCenter, cCenter)

返回矩阵中的所有单元格的坐标,并按与 (rCenter, cCenter) 的 距离 从最小到最大的顺序排。你可以按 任何 满足此条件的顺序返回答案。

单元格(r1, c1)(r2, c2) 之间的距离为|r1 - r2| + |c1 - c2|

示例 1:

输入:rows = 1, cols = 2, rCenter = 0, cCenter = 0
输出:[[0,0],[0,1]]
解释:从 (r0, c0) 到其他单元格的距离为:[0,1]

示例 2:

输入:rows = 2, cols = 2, rCenter = 0, cCenter = 1
输出:[[0,1],[0,0],[1,1],[1,0]]
解释:从 (r0, c0) 到其他单元格的距离为:[0,1,1,2]
[[0,1],[1,1],[0,0],[1,0]] 也会被视作正确答案。

示例 3:

输入:rows = 2, cols = 3, rCenter = 1, cCenter = 2
输出:[[1,2],[0,2],[1,1],[0,1],[1,0],[0,0]]
解释:从 (r0, c0) 到其他单元格的距离为:[0,1,1,2,2,3]
其他满足题目要求的答案也会被视为正确,例如 [[1,2],[1,1],[0,2],[1,0],[0,1],[0,0]]。

提示:

1 <= rows, cols <= 100

0 <= rCenter < rows

0 <= cCenter < cols

二 分析

这个问题其实用任何排序都可以做, 不用那么暴力还把 (r0,c0) 周围的单元格全部遍历一遍

解题的关键在于定义好 less 函数, 相当于 Comparable 接口中的 compareTo 方法

步骤分为两步

构建一个二维数组

比较大小排序即可 我这里使用快速排序

三 答案

class Solution {
     public  int[][] allCellsDistOrder(int R, int C, int r0, int c0) {
        int[][] a = new int[R * C][2];
        for (int i = 0; i < R; i++) {
            for (int j = 0; j < C; j++) {
                a[i * C + j] = new int[]{i, j};
            }
        }
        sort(a, 0, a.length - 1, r0, c0);
        return a;
    }
    private static void sort(int[][] a, int lo, int hi, int r0, int c0) {
        if (hi <= lo) {
            return;
        }
        int j = partition(a, lo, hi, r0, c0);
        sort(a, lo, j - 1, r0, c0);
        sort(a, j + 1, hi, r0, c0);
    }
 private static int partition(int[][] a, int lo, int hi, int r0, int c0) {
        int i = lo;
        int j = hi + 1;
        while (true) {
            while (less(a, ++i, lo, r0, c0)) {
                if (i >= hi) {
                    break;
                }
            }
            while (less(a, lo, --j, r0, c0)) {
                if (j <= lo) {
                    break;
                }
            }
            if (i >= j) {
                break;
            }
            swap(a, i, j);
        }
        swap(a, lo, j);
        return j;
    }
    private static void swap(int[][] a, int i, int j) {
        int[] tmp = a[i];
        a[i] = a[j];
        a[j] = tmp;
    }
    private static boolean less(int[][] a, int i, int j, int ro, int c0) {
        int[] arr1 = a[i];
        int[] arr2 = a[j];
        int len1 = Math.abs(arr1[0] - ro) + Math.abs(arr1[1] - c0);
        int len2 = Math.abs(arr2[0] - ro) + Math.abs(arr2[1] - c0);
        return len1 - len2 < 0;
    }
}

以上就是go语言LeetCode题解1030距离顺序排列矩阵单元格的详细内容,更多关于go 距离顺序排列矩阵单元格的资料请关注脚本之家其它相关文章!

相关文章

  • 超全讲解Golang中defer关键字的用法

    超全讲解Golang中defer关键字的用法

    本文将从一个资源回收问题引入,引出defer关键字,并对其进行基本介绍,从而让大家对Go语言中的defer有更深入的了解,需要的小伙伴可以学习一下
    2023-05-05
  • 完美解决go Fscanf 在读取文件时出现的问题

    完美解决go Fscanf 在读取文件时出现的问题

    这篇文章主要介绍了完美解决go Fscanf 在读取文件时出现的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • Go语言学习笔记之golang操作MongoDB数据库

    Go语言学习笔记之golang操作MongoDB数据库

    MongoDB是Nosql中常用的一种数据库,这篇文章主要给大家介绍了关于Go语言学习笔记之golang操作MongoDB数据库的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • Golang Gin局部和全局中间件使用详解

    Golang Gin局部和全局中间件使用详解

    中间件是放在客户端和服务端的中间,当你的客户端对某个接口发起一个请求,但是在到达接口2之前,这里是有一层中间件的处理。本文详细介绍了Golang Gin局部、全局中间件使用方法,感兴趣的同学可以阅读本文
    2023-04-04
  • Go语言判断指定文件是否存在的方法

    Go语言判断指定文件是否存在的方法

    这篇文章主要介绍了Go语言判断指定文件是否存在的方法,实例分析了Go语言针对文件操作的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • Go实现List、Set、Stack、Deque等数据结构的操作方法

    Go实现List、Set、Stack、Deque等数据结构的操作方法

    Go语言团队的一个核心目标是保持语言的简单性,他们认为,如果一个功能可以用简单的组合来实现,那就没有必要把它放进标准库里,本文给大家介绍Go实现List、Set、Stack、Deque等数据结构的操作方法,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • Go语言实现遍历文件夹

    Go语言实现遍历文件夹

    这篇文章主要为大家详细介绍了Go语言实现遍历文件夹的相关方法,文中的示例代码讲解详细,具有一定的参考价值,感兴趣的小伙伴可以了解一下
    2023-05-05
  • Golang中Set类型的实现方法示例详解

    Golang中Set类型的实现方法示例详解

    这篇文章主要给大家介绍了关于Golang中Set类型实现的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-09-09
  • Golang学习笔记(五):函数

    Golang学习笔记(五):函数

    这篇文章主要介绍了Golang学习笔记(五):函数的相关资料,本文讲解了基本语法、多返回值及命名返回参数、参数传递:传值与传指针、参数传递:可变参数、匿名函数、函数作为值、类型等内容,需要的朋友可以参考下
    2015-05-05
  • go代码实现买房贷款月供计算的方法

    go代码实现买房贷款月供计算的方法

    今天小编就为大家分享一篇关于go代码实现买房贷款月供计算的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-04-04

最新评论