关闭

UVA136 - Ugly Numbers(丑数)

标签: uva
217人阅读 评论(0) 收藏 举报
分类:

作者:xq的acm之路

题目链接:

https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=72

题目大意:丑数是指不能被2,3,5整除的数,把丑数从小到大排列起来,结果如下:1,2,3,4,5,6,8,9,10,12,15,。。。。。
求第1500个丑数。

思路:用优先队列找,这里提供一个越小的整数优先级越大的优先队列,即priority_queue

#include <iostream>
#include <set>
#include <queue>
#include <vector>

using namespace std;
typedef long long LL;
const int chou[3]= {2,3,5};

int main()
{
    priority_queue<LL,vector<LL>,greater<LL> >pq;
    set<int>s;
    pq.push(1);
    s.insert(1);
    for(int i=1;; i++)
    {
        LL x=pq.top();
        pq.pop();
        if(i==1500)
        {
            cout<<"The 1500'th ugly number is "<<x<<"."<<endl;
            break;
        }
        for(int j=0; j<3; j++)
        {
            LL x2=x*chou[j];
            if(!s.count(x2))
            {
                s.insert(x2);
                pq.push(x2);
            }
        }
    }
    return 0;
}
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

丑数 uva-136 丑数

代码如下: /*丑数是指不能被2、3、5以外的其他素数整除的数,把丑数从小到大排列起来,结果如下: 1,2,3,4,5,6,8,9,10,12,15... 求出第1500个丑数。 */ #inclu...
  • u014004096
  • u014004096
  • 2014-11-25 21:26
  • 872

丑数 uva-136 丑数

代码如下: /*丑数是指不能被2、3、5以外的其他素数整除的数,把丑数从小到大排列起来,结果如下: 1,2,3,4,5,6,8,9,10,12,15... 求出第1500个丑数。 */ #inclu...
  • u014004096
  • u014004096
  • 2014-11-25 21:26
  • 872

UVA136 Ugly Numbers【set】

Ugly numbers are numbers whose only prime factors are 2, 3 or 5. The sequence 1, 2, 3, 4, 5, 6, 8, ...
  • tigerisland45
  • tigerisland45
  • 2016-08-06 09:08
  • 678

uva136(优先队列)

题意: 不能被2,3,5以外的素数整除的数,称为丑数;找出第1500个丑数; 思路: 用优先队列和map判重; 如果x是丑数,则2x,3x,5x都是丑数; 不停的放出优先队列; 并...
  • yeyeyeguoguo
  • yeyeyeguoguo
  • 2015-03-31 20:20
  • 791

杭电1058——Humble Numbers(丑数问题)

原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1058任何一个数分解到最后都是由一些质数或者1相乘。基于此,题目中将一个数的质数因子在2,3,5,7之中...
  • qianchangdiyin
  • qianchangdiyin
  • 2016-03-03 12:56
  • 1575

把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。

import java.util.Scanner; /** * 把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。 * 习惯上我们把...
  • pomay
  • pomay
  • 2017-07-05 17:16
  • 1498

STL-UVA136-Ugly Numbers

思路: 从1开始往上*2 *3 *5,记录未出现过的元素。 收获 优先队列,set的find,count查找 #include #include #include #include u...
  • qq_33951440
  • qq_33951440
  • 2016-11-02 19:25
  • 218

UVA136解题报告

先来份错误代码,亲爱的伴们,希望你们能找到其中的问题,顺便说一句,用的是广搜 #include #include using namespace std; int main() { queu...
  • DongChengRong
  • DongChengRong
  • 2017-05-11 06:48
  • 200

LintCode笔记(8)——丑数II

Ugly number is a number that only have factors 2, 3 and 5. Design an algorithm to find the nth ugly ...
  • lhanchao
  • lhanchao
  • 2016-08-01 08:28
  • 1354

剑指Offer面试题34(java版):丑数

题目:丑数  * 我们把只包含因子2,3,5的数称为丑数(Ugly Number).  * 求按从小到大的顺序的第1500个丑数。  * 例如6,8都是丑数,但14不是,因为它含有因子7.习惯上...
  • jsqfengbao
  • jsqfengbao
  • 2015-08-09 15:44
  • 3178
    个人资料
    • 访问:12336次
    • 积分:868
    • 等级:
    • 排名:千里之外
    • 原创:76篇
    • 转载:2篇
    • 译文:0篇
    • 评论:3条