news 2026/2/24 23:57:34

UVa 136 Ugly Numbers

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 136 Ugly Numbers

题目描述

“丑数”(Ugly Numbers\texttt{Ugly Numbers}Ugly Numbers)是指那些质因数只包含222333555的正整数。通常约定111也算作丑数。前111111个丑数为:

1, 2, 3, 4, 5, 6, 8, 9, 10, 12, 15, … 1,\ 2,\ 3,\ 4,\ 5,\ 6,\ 8,\ 9,\ 10,\ 12,\ 15,\ \dots1,2,3,4,5,6,8,9,10,12,15,

本题要求编写程序,找出并输出第150015001500个丑数。

输入格式

无输入。

输出格式

输出一行,格式为:

The 1500'th ugly number is <number>.

其中<number>应替换为计算出的第150015001500个丑数。


题目分析

我们需要生成一个序列,序列中的每个数都满足:其质因数只包含222333555。换句话说,对于任意丑数nnn,存在非负整数aaabbbccc,使得:

n=2a×3b×5c n = 2^a \times 3^b \times 5^cn=2a×3b×5c

本题的核心在于按顺序生成丑数,并找到第150015001500个。


解题思路

方法一:模拟法(朴素判断)

一种直接的方法是:从111开始逐个判断每个正整数是否为丑数,直到找到第150015001500个为止。

判断丑数的方法:

  • 将该数不断除以222333555,直到不能再被这三个数整除。
  • 若最终结果为111,则该数是丑数。

优点:实现简单,易于理解。
缺点:效率较低,因为需要检查很多非丑数。不过对于第150015001500个丑数,其值并不大(约为8.5×1058.5 \times 10^58.5×105)。

时间复杂度O(nlog⁡n)O(n \log n)O(nlogn),其中nnn是第150015001500个丑数的值。


方法二:优先队列法(高效生成)

我们可以利用最小堆(优先队列)来按顺序生成丑数:

  1. 初始化一个最小堆,将111压入堆中。
  2. 每次从堆中取出最小元素xxx,它就是当前最小的丑数。
  3. x×2x \times 2x×2x×3x \times 3x×3x×5x \times 5x×5压入堆中(若尚未出现过)。
  4. 用一个集合记录已生成的丑数,避免重复入堆。
  5. 重复上述过程,直到取出第150015001500个丑数。

优点:只生成丑数,无需判断非丑数,效率高。
缺点:需要额外的数据结构(堆和集合)。

时间复杂度O(nlog⁡n)O(n \log n)O(nlogn),其中n=1500n = 1500n=1500


代码实现

方法一代码(模拟法)

// Ugly Numbers// UVa ID: 136// Verdict: Accepted// Submission Date: 2016-01-08// UVa Run Time: 0.000s//// 版权所有(C)2016,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;intmain(){longlongintstart=1;intcounter=1;while(counter<1500){start++;longlongintnumber=start;while(number%2==0)number/=2;while(number%3==0)number/=3;while(number%5==0)number/=5;if(number==1)counter++;}cout<<"The 1500'th ugly number is "<<start<<"."<<endl;return0;}

方法二代码(优先队列法)

// Ugly Numbers// UVa ID: 136// Verdict: Accepted// Submission Date: 2016-01-08// UVa Run Time: 0.000s//// 版权所有(C)2016,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;typedeflonglongintbigNumber;intmain(){intfactors[3]={2,3,5};set<bigNumber>uglyNumbers;priority_queue<bigNumber,vector<bigNumber>,greater<bigNumber>>candidates;candidates.push(1);for(inti=1;i<=1500;i++){bigNumber top;do{top=candidates.top();candidates.pop();}while(uglyNumbers.count(top)>0);uglyNumbers.insert(top);for(intj=0;j<3;j++){bigNumber next=top*factors[j];if(uglyNumbers.count(next)==0)candidates.push(next);}if(i==1500){cout<<"The 1500'th ugly number is "<<top<<"."<<endl;break;}}return0;}

总结

本题展示了两种生成丑数的方法:

  • 模拟法:简单直接,适合输入规模不大的情况。
  • 优先队列法:高效且可扩展,适合需要生成大量丑数的场景。

两种方法均能快速通过,输出结果一致。对于此类“按条件生成序列”的问题,优先队列法是一种非常实用的技巧。

最终答案:第150015001500个丑数为859963392859963392859963392

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/24 12:44:47

百考通AI:引领智能学习新纪元,打造个性化备考全能助手

在信息爆炸的时代&#xff0c;每一位考生都面临着海量知识筛选、高效复习规划与精准应试训练的多重挑战。如何从繁杂的学习资料中快速提取重点&#xff1f;如何在有限时间内实现系统化知识掌握&#xff1f;如何借助科技力量实现高效、个性化、科学化的备考&#xff1f;百考通AI…

作者头像 李华
网站建设 2026/2/23 16:04:00

百考通AI:您的智能文献研究伙伴,从标题到参考文献一站智成

在学术研究和论文写作的道路上&#xff0c;文献工作往往是最耗时却又最关键的环节。选题初期如何快速建立知识图谱&#xff1f;文献综述怎样才能既全面又有深度&#xff1f;参考文献格式整理为何总是繁琐易错&#xff1f;百考通AI&#xff08;https://www.baikaotongai.com&…

作者头像 李华
网站建设 2026/2/23 17:53:24

百考通AI:您的智能问卷设计专家,让调研从“耗时耗力”到“一键生成”

在市场研究、用户洞察、学术调查乃至内部管理的每一个环节&#xff0c;一份设计精良的问卷都是获取有效数据、驱动决策的关键起点。然而&#xff0c;设计一份既能精准捕捉信息、又能保证用户体验的问卷&#xff0c;往往需要耗费大量的时间与专业技巧。从确定目标、筛选受众、构…

作者头像 李华
网站建设 2026/2/23 19:27:52

HoRain云--高效管理多版本开发环境全攻略

&#x1f3ac; HoRain 云小助手&#xff1a;个人主页 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站&#xff0c;性价比超高&#xff0c;大内存超划算&#xff01;忍不住分享一下给大家。点击跳转到网站。 目录 ⛳️ 推荐 …

作者头像 李华
网站建设 2026/2/24 17:49:29

U+0000 – U+007F的庖丁解牛

U0000 – U007F 是 Unicode 标准中定义的“基本拉丁文”区块&#xff08;Basic Latin&#xff09;&#xff0c;也是 ASCII 字符集的完整映射范围。它不仅是现代文本编码的基石&#xff0c;更是 UTF-8 兼容性的核心设计依据。 一、历史与标准&#xff1a;ASCII 的数字化遗产 ▶…

作者头像 李华
网站建设 2026/2/23 10:22:29

跨平台统一测试框架构建方法论

1. 跨平台测试框架的概述 随着软件应用的多样化发展&#xff0c;跨平台测试框架成为确保产品在多环境&#xff08;如Windows、iOS、Android、Linux&#xff09;下一致性和可靠性的关键工具。这种框架通过统一标准&#xff0c;简化测试流程&#xff0c;提升效率&#xff0c;同时…

作者头像 李华