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

市场营销专业网站南京seo顾问

市场营销专业网站,南京seo顾问,flash做的网站,java web音乐网站开发1. 题目描述 丑数 2. 思路 很明显,丑数就是 2 , 3 , 5 2,3,5 2,3,5 的乘积组合。 最一开始,我竟然傻傻的 d f s dfs dfs s e t set set 来求解,其实仔细想想, d f s dfs dfs 肯定是不行的,因为 d f s dfs dfs 会…

1. 题目描述

丑数



2. 思路

很明显,丑数就是 2 , 3 , 5 2,3,5 2,3,5 的乘积组合。
最一开始,我竟然傻傻的 d f s dfs dfs + s e t set set 来求解,其实仔细想想, d f s dfs dfs 肯定是不行的,因为 d f s dfs dfs 会一条路走到黑。
理想情况下,我们希望每个丑数都按位置放置,而不是跳着来的,例如, 6 6 6 之后的丑数应该是 8 8 8,而不是 9 9 9
对于下一个丑数来说,他只有三种可能:

pre1 * 2;
pre2 * 3;
pre3 * 5;

pre1, pre2, pre3 可能是不同的数。我们希望每次都选取这个组合的最小值,并且刚好是下一个丑数。
那么我们就需要保证,pre1,pre2,pre3 不能大了,也不能小,并且它们都是一个个整数。
好吧,我承认我的论述有点乱,从实际的例子出发好了。
最开始,有一个特殊的丑数 1 1 1,从 1 1 1 出发,有:

1 * 2 = 2;
1 * 3 = 3;
1 * 5 = 5;

我们应该选择 2 2 2,那么,此时 p r e 1 pre1 pre1 也就是 1 ∗ 2 1*2 12 中的 1 1 1 就要编程 2 2 2 了, 2 2 2 就是 1 1 1 之后的最近的丑数。即:

2 * 2 = 4;
1 * 3 = 3;
1 * 5 = 5;

此时我们应该选择 3 3 3,那么,又变成:

2 * 2 = 4;
2 * 3 = 6;
1 * 5 = 5;

选择 4 4 4,变成;

3 * 2 = 6;
2 * 3 = 6;
1 * 5 = 5;

选择 5 5 5,变成:

3 * 2 = 6;
2 * 3 = 6;
2 * 5 = 10;

选择 6 6 6,但是此时有两个 6 6 6 同时出现,我们同时修改 p r e 2 pre2 pre2 p r e 3 pre3 pre3,因为不可以重复:

4 * 2 = 8;
3 * 3 = 9;
2 * 5 = 10;

那么,自然而然的,我们可以通过一种类似三指针的方式,求解。



3. 代码

class Solution {
public:int nthUglyNumber(int n) {int f[n + 10];f[0] = 1;int pre1 = 0, pre2 = 0, pre3 = 0;for(int i = 1; i <= n; i ++ ) {int a = f[pre1] * 2, b = f[pre2] * 3, c = f[pre3] * 5;int minx = min({a, b, c});f[i] = minx;// 注意下面不能都用if-else// 因为丑数不可以重复出现if(a == minx)   pre1 ++ ;if(b == minx)   pre2 ++ ;if(c == minx)   pre3 ++ ;}return f[n - 1];}
};

4. 思路2,贪心 + 优先队列 + set

思路就是,每次选取一个最小值 x x x ,将它发展出来的三个丑数 x ∗ 2 x*2 x2, x ∗ 3 x*3 x3, x ∗ 5 x*5 x5 放到优先队列当中。
然后,将每次从优先队列取出来的数放到哈希表中,当放入哈希表中的数的个数为 n n n 时,就表示我们取出来最小的 n n n 个丑数。
然后,就是注意去重就行了。

5. 代码

class Solution {
public:int nthUglyNumber(int n) {priority_queue<long long, vector<long long>, greater<long long>> q;unordered_set<int> s;int start = 1;q.push(start);while(q.size()) {auto t = q.top();   q.pop();if(s.count(t))  continue;   // 去重s.insert(t);if(s.size() == n)   return t;q.push(t * 2);q.push(t * 3);q.push(t * 5);}return -1;}
};

6. 总结

其实呢,这题,想到是不太好想,看别人的分析也不太容易看懂,但是看代码就一看就懂了。
其实这题,就像贪心,因为丑数只能从另一个丑数通过 pre1*2,pre2*3,pre3*5(pre都是丑数),的方式得到,因此,找出 n n n 个丑数时很容易的。
难点在于,如何保证这 n n n 个丑数恰好是最小的 n n n 个呢?贪心呗!
如果,我们希望通过 pre1*2,pre2*3,pre3*5 得到的丑数尽可能的小,那么,pre1, pre2, pre3 当然也要尽可能的小,那么,我们就每次枚举最小的 pre
如果使用过了,就要增大 pre,并且我们希望增大的幅度近可能的小,那么与 p r e pre pre 相邻的那个丑数就是最好的选择了!
另外,当我们需要增加 p r e pre pre 时,与 p r e pre pre 相邻的丑数一定存在,因为只要增大,就意味着我们找到了一个新的丑数。

http://www.dtcms.com/wzjs/509386.html

相关文章:

  • 上海电子手工活外发加工网天津优化代理
  • 做食物网站应该考虑些什么新手怎么学网络运营
  • wordpress 取消自豪2021百度新算法优化
  • 政府网站ipv6建设方案培训学校
  • 帝国cms灵动标签做网站地图附近学电脑培训班
  • 海外主机做黄色网站上海网站推广服务公司
  • 在线购物商城网站百度搜索引擎推广
  • 长春seo公司网站品牌形象推广
  • 自响应式网站建设清单百度推广有效果吗
  • 哪个网站可以做公务员题廊坊网站排名优化公司哪家好
  • 网站建设收费标准百度权重
  • 什么软件做网站链接怎么让关键词快速上首页
  • 网上做设计兼职哪个网站好点松松软文
  • 做公司网站要收费吗网页入口网站推广
  • 网站开发和运营维护百度推广怎么收费
  • 临海响应式网站设计十大新媒体平台有哪些
  • 网站虚拟主机哪个好宁波seo推广定制
  • 怎样做网站快照简述网站推广的方式
  • 如何本地搭建自己的网站科技网站建设公司
  • 做网站和软件的团队大地seo
  • 做网站需要什么工具小升初最好的补课机构排行榜
  • 网站建设通查询东莞网站到首页排名
  • 做暖暖视频网站观看百度代运营公司
  • SFDA的网站建设是什么seo网站优化课程
  • 不能上传图片到网站seo销售是做什么的
  • 杭州哪个网站建设最好杭州seo网站建设
  • 做网站要在工商备案吗seo外包费用
  • 男女做姿抽插视频网站想要推广页
  • Java电商网站开发资源网站推广优化c重庆
  • 北京泵网站建设免费网站推广群发软件