排序矩阵中的从小到大第k个数 · Kth Smallest Number In Sorted Matrix
[抄题]:
在一个排序矩阵中找从小到大的第 k 个整数。
排序矩阵的定义为:每一行递增,每一列也递增。
[思维问题]:
不知道应该怎么加,因为不是一维单调的。
[一句话思路]:
周围两个数给x或y挪一位, 如果hash数组没有就添加到minheap中
[输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入):
[画图]:

[一刷]:
- class Pair(没有参数)中要有数据类型、方法Pair(int x , int y, int val)
 - PairComparator 继承了 Comparator<Pair>类 里面自然就是对pair进行比较, 接口<内容物>+名 = new 内部结构名<内容物>。Queue xx = new PQ<Integer>(k,新建pair对象) 0,0,matrix[0][0] 也要新建对象 new Pair
 - x坐标用dx表示, 里面只有0,1
 - 取出数从i = 1开始,不用从0开始。因为第一个符合条件的pair是(0,0,matrix[0][0])。
 - 数组不包括,直接用!hash[x][y]即可
 
[二刷]:
- class关键字是小写开头
 - next_pair新建之后,minheap直接add(next_pair)即可
 - dx,dy数组的作用是加一位坐标,因此里面有东西:0 或 1
 
[三刷]:
- paircomparator类是继承来的,别的地方可以用,所以写class
 
[四刷]:
[五刷]:
[总结]:
[复杂度]:Time complexity: O(klgk) Space complexity: O(k)
[英文数据结构,为什么不用别的数据结构]:
heap符合每次取顶 丢掉,取到k个为止
[其他解法]:
二分法
[Follow Up]:
[LC给出的题目变变变]:
373. Find K Pairs with Smallest Sums 也是用minheap实现取最小
668. Kth Smallest Number in Multiplication Table 看着像用heap,其实用二分法 玩数学
719. Find K-th Smallest Pair Distance 其实用二分法 玩数学。看来二分法也能用于查找最小的第k个数
public class Solution {
    /*
     * @param matrix: a matrix of integers
     * @param k: An integer
     * @return: the kth smallest number in the matrix
     */
    public int kthSmallest(int[][] matrix, int k) {
        class Pair {
            int x,y,val;
            public Pair(int x,int y,int val) {
                this.x = x;
                this.y = y;
                this.val = val;
            }
        };
        class PairComparator implements Comparator<Pair>{
            public int compare(Pair a,Pair b) {
                return a.val - b.val;
            }
        };
        int m = matrix.length;
        int n = matrix[0].length;
        int[] dx = new int[]{0,1};
        int[] dy = new int[]{1,0};
        boolean[][] hash = new boolean[m][n];
        Queue<Pair> minHeap = new PriorityQueue<Pair>(k,new PairComparator());
        minHeap.add(new Pair(0,0,matrix[0][0]));
        for (int i = 1; i < k; i++) {
            Pair cur = minHeap.poll();
            for (int j = 0; j < 2; j++) {
                int next_x = cur.x + dx[j];
                int next_y = cur.y + dy[j];
                Pair next_Pair = new Pair(next_x,next_y,0);
                if (next_x < m && next_y < n && !hash[next_x][next_y]) {
                    next_Pair.val = matrix[next_x][next_y];
                    hash[next_x][next_y] = true;
                    minHeap.add(next_Pair);
                }
            }
        }
        return minHeap.peek().val;
    }
}
排序矩阵中的从小到大第k个数 · Kth Smallest Number In Sorted Matrix的更多相关文章
- lintcode-401-排序矩阵中的从小到大第k个数
		
401-排序矩阵中的从小到大第k个数 在一个排序矩阵中找从小到大的第 k 个整数. 排序矩阵的定义为:每一行递增,每一列也递增. 样例 给出 k = 4 和一个排序矩阵: [ [1 ,5 ,7], [ ...
 - [LintCode] Kth Smallest Number in Sorted Matrix 有序矩阵中第K小的数字
		
Find the kth smallest number in at row and column sorted matrix. Have you met this question in a rea ...
 - 找到排序矩阵中从小到大第K个数字
		
一 题目描述 在一个排序矩阵中找从小到大的第 k 个整数. 排序矩阵的定义为:每一行递增,每一列也递增. 二 题解 由于排序矩阵中的每一行都是递增的,并且每一列都是递增的.从小到大第k个数,实际上就是 ...
 - python 判断矩阵中每行非零个数的方法
		
python 判断矩阵中每行非零个数的方法: # -*- coding: utf-8 -*- # @Time : 2018/5/17 15:05 # @Author : Sizer # @Site : ...
 - [LeetCode] Kth Smallest Number in Multiplication Table 乘法表中的第K小的数字
		
Nearly every one have used the Multiplication Table. But could you find out the k-th smallest number ...
 - [Swift]LeetCode668. 乘法表中第k小的数 | Kth Smallest Number in Multiplication Table
		
Nearly every one have used the Multiplication Table. But could you find out the k-th smallest number ...
 - LeetCode1337矩阵中最弱的K行
		
题目 给你一个大小为 m * n 的矩阵 mat,矩阵由若干军人和平民组成,分别用 1 和 0 表示. 请你返回矩阵中战斗力最弱的 k 行的索引,按从最弱到最强排序. 如果第 i 行的军人数量少于第 ...
 - 找出一堆数中最小的前K个数
		
描写叙述: 给定一个整数数组.让你从该数组中找出最小的K个数 思路: 最简洁粗暴的方法就是将该数组进行排序,然后取最前面的K个数就可以. 可是,本题要求的仅仅是求出最小的k个数就可以,用排序能够但显然 ...
 - matlab求一个矩阵中各元素出现的个数(归一化)
		
function [m,n] = stamatrix(a) %网上找到的方法,感觉很巧妙 x=a(:); x=sort(x); d=diff([x;max(x)+1]); count = diff(f ...
 
随机推荐
- Fix-Dell iDRAC 7 error: RAC0218: The maximum number of user sessions is reached
			
Hi Everyone, We came across the following error while performing some preventative maintenance check ...
 - [UE4]射中机器人
 - ThinkPHP 5使用 Composer  组件名称可以从https://packagist.org/ 搜索到
			
http://www.phpcomposer.com/ 1 这个是国内的composer网站 thinkphp5自带了composer.phar组件,如果没有安装,则需要进行安装 以下命令全部在项目目 ...
 - 第1课 学习 C++ 的意义
			
1. 回顾历史 (1)UNIX操作系统诞生之初是直接用汇编语言写成的.随着UNIX的发展,汇编语言的开发效率成为一个瓶劲. (2)1971年,Ken Thompson和Denis Ritchie对B ...
 - express无中间件的增删改查
			
index.js const express = require("express");导入express框架 const data = require("./data& ...
 - 并发基础(八) java线程的中断机制
			
文章转载自 详细分析Java中断机制 1. 引言 当我们点击某个杀毒软件的取消按钮来停止查杀病毒时,当我们在控制台敲入quit命令以结束某个后台服务时--都需要通过一个线程去取消另一个线程正在执行的任 ...
 - 技术思维VS管理思维
			
以下为技术思维与管理思维的不同 在日常的工作中,会出现身兼两职 开发和项目经理 的情况,在此就要学会游刃有余的切换角色,方能一人分身二角 角色转换本质上是思维转换.思维决定一个人的行为,项目经理不像项 ...
 - 温故而知新-PHP文件操作函数
			
1 文件操作流程 打开文件->读取或者写入文件->关闭文件 fopen->fread,fwrite->fclose fopen可以打开ftp或者http协议的文件,前提示对方支 ...
 - DateFrame
			
DateFrame 早期叫作SchemaRDD是存放Row 对象的RDD,每个Row 对象代表一行记录. SchemaRDD 还包含记录的结构信息(即数据字段).SchemaRDD 看起来和普通的RD ...
 - leetcode965
			
public class Solution { List<int> list = new List<int>(); private void postTree(TreeNode ...