当前位置: 首页 > article >正文

leetcode1201. 丑数 III -medium

1 题目:1201. 丑数 III.

官方标定难度:中

丑数是可以被 a 或 b 或 c 整除的 正整数 。

给你四个整数:n 、a 、b 、c ,请你设计一个算法来找出第 n 个丑数。

示例 1:

输入:n = 3, a = 2, b = 3, c = 5
输出:4
解释:丑数序列为 2, 3, 4, 5, 6, 8, 9, 10… 其中第 3 个是 4。

示例 2:

输入:n = 4, a = 2, b = 3, c = 4
输出:6
解释:丑数序列为 2, 3, 4, 6, 8, 9, 10, 12… 其中第 4 个是 6。

示例 3:

输入:n = 5, a = 2, b = 11, c = 13
输出:10
解释:丑数序列为 2, 4, 6, 8, 10, 11, 12, 13… 其中第 5 个是 10。

提示:

1 < = n , a , b , c < = 10 9 1 <= n, a, b, c <= 10^9 1<=n,a,b,c<=109
1 < = a ∗ b ∗ c < = 10 18 1 <= a * b * c <= 10^{18} 1<=abc<=1018
本题结果在 [ 1 , 2 ∗ 10 9 ] [1, 2 * 10^9] [1,2109] 的范围内

2 solution

本题数据规模很大,缺乏高效的递推公式,但是答案又是要验证的而且具有连续性,所以可以用二分法。

代码

class Solution {/** 二分法*/long long gcd(long long x, long long y) {if (y == 0) return x;return gcd(y, x % y);}public:int nthUglyNumber(int n, int a, int b, int c) {long long l = 1, r = 2e9;long long ab = 1ll * a * b / gcd(a, b);long long ac = 1ll * a * c / gcd(a, c);long long bc = 1ll * b * c / gcd(b, c);long long abc = 1ll * ab / gcd(ab, bc) * bc ;while (l < r) {long long mid = (l + r) >> 1;long long m = mid / a + mid / b + mid / c - mid / ab - mid / bc - mid / ac + mid / abc;if(m >= n) r = mid;else l = mid + 1;}return r;}
};

结果

在这里插入图片描述

http://www.lryc.cn/news/2393969.html

相关文章:

  • ai工具集:AI材料星ppt生成,让你的演示更出彩
  • @Prometheus 监控操作系统-Exporter(Win Linux)
  • LINUX530 rsync定时同步 环境配置
  • CMG 机器人格斗大赛举行,宇树人形机器人参赛,比赛有哪些看点?对行业意味着什么?
  • Python——MySQL远程控制
  • 异常:UnsupportedOperationException: null
  • Ubuntu 24.04 LTS 和 ROS 2 Jazzy 环境中使用 Livox MID360 雷达
  • 自动化立体仓库堆垛机SRM控制系统FC19手动控制功能块开发
  • Ollama(1)知识点配置篇
  • VMware Workstation虚拟系统设置双网口
  • Qt基础终结篇:从文件操作到多线程异步UI,深度解析核心要点
  • ubuntu中,文本编辑器nano和vim区别,vim的用法
  • 山洪灾害声光电监测预警解决方案
  • 【Rust模式与匹配】Rust模式与匹配深入探索与应用实战
  • React从基础入门到高级实战:React 高级主题 - React Concurrent 特性:深入探索与实践指南
  • electron安装报错处理
  • NHANES指标推荐:CQI
  • 【OpenHarmony】【交叉编译】使用gn在Linux编译3568a上运行的可执行程序
  • Med-R1论文阅读理解-1
  • 【从零开始学习QT】快捷键、帮助文档、Qt窗口坐标体系
  • 强化学习笔记总结(结合论文)
  • Java线程安全解决方案全面指南
  • superior哥深度学习系列(大纲)
  • 基于stm32的多旋翼无人机(Multi-rotor UAV based on stm32)
  • 实验分享|基于sCMOS相机科学成像技术的耐高温航空涂层材料损伤检测实验
  • RAG混合检索:倒数秩融合RRF算法
  • 2011肠衣问题
  • RG3000网关构建5G LAN智慧工厂智能制造
  • Rust语言学习教程、案例与项目实战指引
  • 通信应用高速模数转换器ADC