剑指Offer - 九度1214 - 丑数
- 
剑指Offer - 九度1214 - 丑数
2013-11-21 21:06- 题目描述:
 - 
把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。
习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。 
- 输入:
 - 
输入包括一个整数N(1<=N<=1500)。
 
- 输出:
 - 
可能有多组测试数据,对于每组数据,
输出第N个丑数。 
- 样例输入:
 - 
3
 
- 样例输出:
 - 
3
 
题意分析:
题目要求按照从小到大的顺序找出因子只有2, 3, 5的第N个数。
由于所有数列中的f(n)都可表示为f(n) = 2 ^ x * 3 ^ y * 5 * z;那么求f(n)必然来自下面三种情况之一:
f(n) = f(a) * 2;
f(n) = f(b) * 3;
f(n) = f(c) * 3;
由于数列从小到大排列,f(n)应该取上述三个结果中最小的一个,去了以后,对应的iterator也应该前移一位。于是有了如下代码。
递推时间复杂度O(n),数组空间复杂度O(n)。
ZOJ 1095 -Humble Number和这题完全一个道理。// 652664 zhuli19901106 1214 Accepted 点击此处查看所有case的执行结果 1020KB 737B 10MS
//
#include <cstdio>
using namespace std; const int &mymin(const int &x, const int &y)
{
return (x < y ? x : y);
} int main()
{
const int MAXN = ;
int a[MAXN + ];
int p2, p3, p5;
int r2, r3, r5;
int minv;
int i; a[] = ;
a[] = ;
p2 = p3 = p5 = ;
for(i = ; i <= MAXN; ++i){
r2 = a[p2] * ;
r3 = a[p3] * ;
r5 = a[p5] * ;
minv = mymin(mymin(r2, r3), r5);
a[i] = minv;
if(minv == r2){
++p2;
}
if(minv == r3){
++p3;
}
if(minv == r5){
++p5;
}
} while(scanf("%d", &i) == ){
if(i >= && i <= MAXN){
printf("%d\n", a[i]);
}
} return ;
} 
剑指Offer - 九度1214 - 丑数的更多相关文章
- 剑指Offer - 九度1504 - 把数组排成最小的数
		
剑指Offer - 九度1504 - 把数组排成最小的数2014-02-06 00:19 题目描述: 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输 ...
 - 剑指Offer - 九度1360 - 乐透之猜数游戏
		
剑指Offer - 九度1360 - 乐透之猜数游戏2014-02-05 19:54 题目描述: 六一儿童节到了,YZ买了很多丰厚的礼品,准备奖励给JOBDU里辛劳的员工.为了增添一点趣味性,他还准备 ...
 - 剑指Offer - 九度1356 - 孩子们的游戏(圆圈中最后剩下的数)
		
剑指Offer - 九度1356 - 孩子们的游戏(圆圈中最后剩下的数)2014-02-05 19:37 题目描述: 每年六一儿童节,JOBDU都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此.H ...
 - 剑指Offer - 九度1373 - 整数中1出现的次数(从1到n整数中1出现的次数)
		
剑指Offer - 九度1373 - 整数中1出现的次数(从1到n整数中1出现的次数)2014-02-05 23:03 题目描述: 亲们!!我们的外国友人YZ这几天总是睡不好,初中奥数里有一个题目一直 ...
 - 剑指Offer - 九度1355 - 扑克牌顺子
		
剑指Offer - 九度1355 - 扑克牌顺子2014-01-30 23:19 题目描述: LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^). ...
 - 剑指Offer - 九度1352 - 和为S的两个数字
		
剑指Offer - 九度1352 - 和为S的两个数字2014-02-05 18:15 题目描述: 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于 ...
 - 剑指Offer - 九度1522 - 包含min函数的栈
		
剑指Offer - 九度1522 - 包含min函数的栈2013-12-01 23:44 题目描述: 定义栈的数据结构,请在该类型中实现一个能够得到栈最小元素的min函数. 输入: 输入可能包含多个测 ...
 - 剑指Offer - 九度1520 - 树的子结构
		
剑指Offer - 九度1520 - 树的子结构2013-11-30 22:17 题目描述: 输入两颗二叉树A,B,判断B是不是A的子结构. 输入: 输入可能包含多个测试样例,输入以EOF结束.对于每 ...
 - 剑指Offer - 九度1513 - 二进制中1的个数
		
剑指Offer - 九度1513 - 二进制中1的个数2013-11-29 23:35 题目描述: 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 输入: 输入可能包含多个测试样例. ...
 
随机推荐
- 22 Swap Nodes in Pairs
			
Given a linked list, swap every two adjacent nodes and return its head. For example,Given 1->2-&g ...
 - java 通过接口在后台管理器中生成数据
			
需求:测试人员在后台批量添加数据很麻烦,特别是针对一款商品配置了英语,还需要手动添加法语.俄语.阿拉伯语,很麻烦,但是因为没有项目组配合,做个小工具批量生成数据就只有自己去研究了 第一步:通过抓包工具 ...
 - Android(java)学习笔记97:使用GridView以及重写BaseAdapter
			
1. BaseAdapter: 对于ListView.GridView.Gallery.Spinner等等,它是它们的适配器,直接继承自接口类Adapter的,使用BaseAdapter时需要重写很多 ...
 - Spring Security 之集群Session配置
			
1. 新建Maven项目 cluster-session 2. pom.xml <project xmlns="http://maven.apache.org/POM/4.0. ...
 - arXiv 上传文章过程
			
arXiv属于预印本服务的一种,是指科研工作者的研究成果还未在正式出版物上发表,而出于和同行交流目的自愿先在学术会议上或通过互联网发布的科研论文.科技报告等文章.与刊物发表的文章以及网页发布的文章 ...
 - HttpServerUtility 和 HttpUyility
			
参考:msdn HttpServerUtility 提供用于处理 Web 请求的 Helper 方法. 2017/08/07 加密解码 这个类没有构造函数,所以不能直接new. ...
 - skimage.io.imread vs caffe.io.load_image
			
这两周在跑一个模型,我真的是被折腾的要崩溃了. 最后原因就是数据类型的问题,你说是不是应该管小黑屋啊. skimage.io.imread得到的是uint8的数据,而caffe.io.load_ima ...
 - 删除已有的 HTML 元素
			
如需删除 HTML 元素,您必须首先获得该元素的父元素: 实例 <div id="div1"> <p id="p1">这是一个段落.&l ...
 - git 学习笔记 window操作系统
			
一.准备工作 1.设置好操作者和邮箱 $ git config --global user.name "Your Name" $ git config --global user. ...
 - DB总结1
			
DBA 重构 data new york committee cobol codasyl journal DDL DML 关系演算 域关系演算语言(QBE) 元祖关系演算语言 ...