力扣668.乘法表中第k小的数

力扣668.乘法表中第k小的数

  • 二分查找

    • 是否有k个比mid小的数
cpp 复制代码
  class Solution {
  public:
      int findKthNumber(int m, int n, int k) {
          auto check = [&](int mid) -> bool
          {
              int res=0;
              int row = 1,col = n;
              while(row <= m)
              {
                  if(row * col <= mid)
                  {
                      res += col;
                      if(res >= k) return false;
                      row ++;
                  }
                  else col --;
              }
              return true;
          };
          int l = 1,r = n * m;
          while(l<r)
          {
              int mid = l + r + 1 >> 1;
              if(check(mid)) l = mid;
              else r = mid - 1;
          }
          return r + 1;
      }
  };
相关推荐
学到头秃的suhian2 分钟前
Springboot进阶知识
java·spring boot·spring
你想知道什么?2 分钟前
JNI简单学习(java调用C/C++)
java·c语言·学习
期待のcode3 分钟前
Thymeleaf模板引擎
java·html·springboot
白宇横流学长7 分钟前
基于SpringBoot实现的电子发票管理系统
java·spring boot·后端
白宇横流学长10 分钟前
基于SpringBoot实现的智慧就业管理系统
java·spring boot·后端
TL滕13 分钟前
从0开始学算法——第十二天(KMP算法练习)
笔记·学习·算法
weixin_4624462315 分钟前
EasyExcel 动态修改模板 Sheet 名称:自定义 SheetWriteHandler 拦截器
java·开发语言·easyexcel
Math_teacher_fan16 分钟前
第二篇:核心几何工具类详解
人工智能·算法
汉克老师17 分钟前
CCF-NOI2025第二试题目与解析(第二题、集合(set))
c++·算法·noi·子集卷积·sos dp·mod 异常
赵庆明老师20 分钟前
NET 使用SmtpClient 发送邮件
java·服务器·前端