博客
关于我
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/

你可能感兴趣的文章
Nginx 源码完全注释(11)ngx_spinlock
查看>>
Nginx 的 proxy_pass 使用简介
查看>>
Nginx 的优化思路,并解析网站防盗链
查看>>
Nginx 的配置文件中的 keepalive 介绍
查看>>
Nginx 结合 consul 实现动态负载均衡
查看>>
Nginx 负载均衡与权重配置解析
查看>>
Nginx 负载均衡详解
查看>>
nginx 配置 单页面应用的解决方案
查看>>
nginx 配置https(一)—— 自签名证书
查看>>
nginx 配置~~~本身就是一个静态资源的服务器
查看>>
Nginx 配置服务器文件上传与下载
查看>>
Nginx 配置清单(一篇够用)
查看>>
Nginx 配置解析:从基础到高级应用指南
查看>>
nginx 集群配置方式 静态文件处理
查看>>
nginx+php的搭建
查看>>
nginx+tomcat+memcached
查看>>
Nginx+Tomcat实现动静分离
查看>>
nginx+Tomcat性能监控
查看>>
nginx+uwsgi+django
查看>>
nginx+vsftp搭建图片服务器
查看>>