博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode:乘法表中的第K小的数【668】
阅读量:5167 次
发布时间:2019-06-13

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

LeetCode:乘法表中的第K小的数【668】

题目描述

几乎每一个人都用 。但是你能在乘法表中快速找到第k小的数字吗?

给定高度m 、宽度n 的一张 m * n的乘法表,以及正整数k,你需要返回表中第k 小的数字。

例 1:

输入: m = 3, n = 3, k = 5输出: 3解释: 乘法表:1	2	32	4	63	6	9第5小的数字是 3 (1, 2, 2, 3, 3).

例 2:

输入: m = 2, n = 3, k = 6输出: 6解释: 乘法表:1	2	32	4	6第6小的数字是 6 (1, 2, 2, 3, 4, 6).

注意:

  1. m 和 n 的范围在 [1, 30000] 之间。
  2. k 的范围在 [1, m * n] 之间。

题目分析

  1.直观思路:首先生成乘法表,将所有数据放到一个集合中,对集合进行排序,但是这道题的数据规模比较大,这张乘法表过于巨大,无法使用暴力

  2.那我们怎么做?

    由于乘法表中的每一行都是排过序的,我们很容易得知某一行有多少元素小于或大于特定值。 这道题数据规模巨大,绝对不可能采用存储并运算的方式,所以诸如堆排序也是不可能的。分析问题我们很明显是查找问题,且数据具有一定的特性,直接思路靠到二分查找上。

  

  3.啥叫数据特性?具体规律是怎样的。

  切记,我们利用这个数据特性是为了快速统计有多少个元素小于或等于特定值

  

  每一行有多少个小于特定值的元素呢,我们可以将特定值x除以i,然后其值就可以看做是个数(因为没有比例放大),如果这个数小于n的话,最多就是x/i,否则就是大于全员,那么这行n个元素全部小于x。然后我们用二分搜索的套路,不断缩小范围,直到找到小于它的元素是K个的。

Java题解

class Solution {    public int findKthNumber(int m, int n, int k) {        int l =1;        int r = m*n+1;        while(l
=k) r=x; else l=x+1; } return l; } private int LEX(int m,int n,int x) { int count = 0; for(int i=1;i<=m;i++) count+=Math.min(n,x/i); return count; }}

  

 

 

 

  

 

转载于:https://www.cnblogs.com/MrSaver/p/9631854.html

你可能感兴趣的文章
js编码
查看>>
Pycharm Error loading package list:Status: 403错误解决方法
查看>>
steps/train_sat.sh
查看>>
转:Linux设备树(Device Tree)机制
查看>>
iOS 组件化
查看>>
(转)Tomcat 8 安装和配置、优化
查看>>
(转)Linxu磁盘体系知识介绍及磁盘介绍
查看>>
tkinter布局
查看>>
命令ord
查看>>
Sharepoint 2013搜索服务配置总结(实战)
查看>>
博客盈利请先考虑这七点
查看>>
使用 XMLBeans 进行编程
查看>>
写接口请求类型为get或post的时,参数定义的几种方式,如何用注解(原创)--雷锋...
查看>>
【OpenJ_Bailian - 2287】Tian Ji -- The Horse Racing (贪心)
查看>>
Java网络编程--socket服务器端与客户端讲解
查看>>
List_统计输入数值的各种值
查看>>
学习笔记-KMP算法
查看>>
Timer-triggered memory-to-memory DMA transfer demonstrator
查看>>
跨域问题整理
查看>>
[Linux]文件浏览
查看>>