博客
关于我
LeetCode 378.有序矩阵中第K小的元素
阅读量:246 次
发布时间:2019-03-01

本文共 1402 字,大约阅读时间需要 4 分钟。

给你一个 n x n 矩阵 matrix ,其中每行和每列元素均按升序排序,找到矩阵中第 k 小的元素。

请注意,它是 排序后 的第 k 小元素,而不是第 k 个 不同 的元素。

用最小堆维护候选集合

每次堆中取出一个元素 将它的右元素和下元素加入候选集合
用数组判断某个元素是否已经被加入过堆

class Solution {       class Node{           int x;        int y;        int val;        public Node(int x, int y, int val){               this.x = x;            this.y = y;            this.val = val;        }    }    class NodeComparator implements Comparator
{ public int compare(Node a, Node b){ return a.val - b.val; } } public int kthSmallest(int[][] matrix, int k) { int n = matrix.length; int[] cx = { 0, 1}; int[] cy = { 1, 0}; boolean[][] hash = new boolean[n][n]; Queue
minheap = new PriorityQueue<>(k, new NodeComparator()); minheap.add(new Node(0, 0, matrix[0][0])); int count = 0; while(!minheap.isEmpty()){ Node node = minheap.poll(); if(++count == k) return matrix[node.x][node.y]; for(int i = 0; i < 2; i++){ if(node.x + cx[i] < n && node.y + cy[i] < n && !hash[node.x + cx[i]][node.y + cy[i]]){ minheap.offer(new Node(node.x + cx[i], node.y + cy[i], matrix[node.x + cx[i]][node.y + cy[i]])); hash[node.x + cx[i]][node.y + cy[i]] = true; } } } return 0; }}

转载地址:http://rtvv.baihongyu.com/

你可能感兴趣的文章
Net.Framework概述
查看>>
NET3.0+中使软件发出声音[整理篇]<转>
查看>>
net::err_aborted 错误码 404
查看>>
NetApp凭借领先的混合云数据与服务把握数字化转型机遇
查看>>
NetAssist网络调试工具使用指南 (附NetAssist工具包)
查看>>
Netbeans 8.1启动参数配置
查看>>
NetBeans IDE8.0需要JDK1.7及以上版本
查看>>
NetBeans之JSP开发环境的搭建...
查看>>
NetBeans之改变难看的JSP脚本标签的背景色...
查看>>
netbeans生成的maven工程没有web.xml文件 如何新建
查看>>
netcat的端口转发功能的实现
查看>>
NetCore 上传,断点续传,可支持流上传
查看>>
Netcraft报告: let's encrypt和Comodo发布成千上万的网络钓鱼证书
查看>>
Netem功能
查看>>
netfilter应用场景
查看>>
Netflix:当你按下“播放”的时候发生了什么?
查看>>
Netflix推荐系统:从评分预测到消费者法则
查看>>
netframework 4.0内置处理JSON对象
查看>>
Netgear WN604 downloadFile.php 信息泄露漏洞复现(CVE-2024-6646)
查看>>
Netgear wndr3700v2 路由器刷OpenWrt打造全能服务器(十一)备份
查看>>