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值类型转换成[]uint8类型的操作

    golang值类型转换成[]uint8类型的操作

    这篇文章主要介绍了golang值类型转换成[]uint8类型的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • 一文深入探讨Go语言中的if-else语句

    一文深入探讨Go语言中的if-else语句

    在Go语言中,条件语句的使用方式相对简洁明了,所以本文将探讨一下如何在Go程序中有效地进行条件判断和逻辑控制,感兴趣的小伙伴可以了解下
    2023-08-08
  • Golang中sync.Mutex的源码分析

    Golang中sync.Mutex的源码分析

    这篇文章将带大家从源码分析一下Golang中sync.Mutex的使用,文中的示例代码讲解详细,对我们学习Golang有一定的帮助,需要的可以参考一下
    2023-03-03
  • Golang中int, int8, int16, int32, int64和uint区别浅析

    Golang中int, int8, int16, int32, int64和uint区别浅析

    go语言中的int的大小是和操作系统位数相关的,如果是32位操作系统,int类型的大小就是4字节,如果是64位操作系统,int类型的大小就是8个字节,下面这篇文章主要给大家介绍了关于Golang中int, int8, int16, int32, int64和uint区别的相关资料,需要的朋友可以参考下
    2022-11-11
  • 详解Go语言中Get/Post请求测试

    详解Go语言中Get/Post请求测试

    这篇文章主要为大家详细介绍了Go语言中的环境安装以及Get和Post请求接口的测试,文中的示例代码讲解详细,感兴趣的可以跟随小编一起学习一下
    2022-06-06
  • 一文带你了解Go语言中的单元测试

    一文带你了解Go语言中的单元测试

    写过单元测试的开发人员应该理解,单元测试最核心的价值是为了证明:为什么我写的代码是正确的?也就是从逻辑角度帮你检查你的代码。本文就来和大家详细聊聊Go语言中的单元测试,需要的可以参考一下
    2022-07-07
  • Go中groutine通信与context控制实例详解

    Go中groutine通信与context控制实例详解

    随着context包的引入,标准库中很多接口因此加上了context参数,下面这篇文章主要给大家介绍了关于Go中groutine通信与context控制的相关资料,需要的朋友可以参考下
    2022-02-02
  • Go语言学习笔记之错误和异常详解

    Go语言学习笔记之错误和异常详解

    Go语言采用返回值的形式来返回错误,这一机制既可以让开发者真正理解错误处理的含义,也可以大大降低程序的复杂度,下面这篇文章主要给大家介绍了关于Go语言学习笔记之错误和异常的相关资料,需要的朋友可以参考下
    2022-07-07
  • Go实现基于RSA加密算法的接口鉴权

    Go实现基于RSA加密算法的接口鉴权

    这篇文章主要介绍了Go实现基于RSA加密算法的接口鉴权,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • 详解Go语言中iota的应用

    详解Go语言中iota的应用

    在本文中,小编将带着大家深入探讨 iota 的神奇力量,包括 iota 的介绍和应用场景以及使用技巧和注意事项,准备好了吗,准备一杯你最喜欢的饮料或茶,随着本文一探究竟吧
    2023-07-07

最新评论