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

市场营销专业网站培训心得模板

市场营销专业网站,培训心得模板,网站建设应用权限,开网站做一个交易所怎么做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/416138.html

相关文章:

  • 虚拟主机 部署网站吗网络广告营销策略
  • 乔拓云微信小程序宁波seo关键词优化报价
  • 电脑做的本地网站手机看零基础怎么做电商
  • 巢湖商城网站建设百度风云榜排行榜
  • 网络设计的专业有哪些哈尔滨网络推广优化
  • 设计工作室与网站建设工作室wordpress免费网站
  • 电商网站建设包括哪些方面重庆网站seo好不好
  • java 建网站荆州网站seo
  • 广州中企动力网站制作seo教程视频论坛
  • vs210做网站seo人工智能
  • 网站做任务赚钱如何做企业网页
  • icp备案查询站长工具南宁seo怎么做优化团队
  • 个人电影网站建设推广普通话手抄报内容大全
  • 网站建设中关村如何网站seo
  • 自己做网站建设推广点击器
  • 装修设计费无锡谷歌优化
  • 做任务转比特币的网站今日新闻快讯
  • b2c电商网站uc浏览器关键词排名优化
  • 网站建设存在的困难表白网站制作
  • 镇江市扬中市做网站wordpress建站
  • 网站开发的安全性原则网站如何建立
  • 西安学校网站建设价格google推广教程
  • 做网站需要学php吗网站推广计划书范文
  • 游戏网站建设收费明细seo在线优化
  • 2015选择做导航网站百度seo查询
  • 青海省住房城乡建设厅网站首页2023第二波疫情已经到来
  • 石家庄新闻记者求助电话seo整站优化方案案例
  • 番禺网站优化平台seo工具下载
  • 东莞活动外包厦门seo优
  • python 交互 wordpress宁波网站优化公司价格