ljiechang 2014-11-24 15:31 采纳率: 0%
浏览 3745

求 第 n 大 的 丑 数

素因子都在集合{2, 3, 5, 7}内的整数称为ugly number 求第n大的丑数
分析
1.初始:把1放入优先队列中
2.每次从优先队列中取出一个元素k,把2k, 3k,5k, 7k放入优先队列中
3.从2开始算,取出的第n个元素就是第n大的丑数
4.每取出一个数,插入4个数,因此任何堆里的元素是O(n)的,时间复杂度为O(nlogn)

  • 写回答

2条回答 默认 最新

  • threenewbee 2014-11-24 18:10
    关注

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;

    namespace ConsoleApplication1
    {
    class Program
    {
    static void Main(string[] args)
    {
    List f = new List() { 2, 3, 5, 7 };
    List q = new List() { 1 };
    int i = 0;
    int n = 30;
    while (i++ < n)
    {
    int k = q.Min();
    q.RemoveAll(x => x == k);
    q.AddRange(f.Select(x => x * k));
    Console.WriteLine(k);
    }
    }
    }
    }

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    12
    14
    15
    16
    18
    20
    21
    24
    25
    27
    28
    30
    32
    35
    36
    40
    42
    45
    48
    49
    请按任意键继续. . .

    评论

报告相同问题?

悬赏问题

  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题