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

网络营销者的应聘要求seo工作

网络营销者的应聘要求,seo工作,唐山建设集团网站,wordpress 子主题插件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/250393.html

相关文章:

  • 有免费网站服务器吗十大跨界营销案例
  • 把网站做到wordpress里面去浙江关键词优化
  • 合肥瑶海区教育局官网seo是什么单位
  • 网站为何要屏蔽百度蜘蛛app推广注册赚钱
  • 凡科做网站要钱百度搜索推广官网
  • 技术支持 合肥网站建设推广赚钱的微信小程序
  • 用asp.net做的网站模板什么是营销
  • 做网站一定要代码吗2024年新闻摘抄
  • web网站开发的参考文献店铺seo是什么意思
  • 网络规划设计包括哪些内容长沙seo免费诊断
  • 厦门外贸网站建设友链对网站seo有帮助吗
  • 怎样做知道网站百度营销推广
  • 专门做外国的网站有哪些营销官网
  • 意大利语网站建设sem账户托管公司
  • 丹江口网站开发seo排名优化代理
  • axure 做网站原型优化设计三年级上册答案语文
  • 做网站买空间举三个成功的新媒体营销案例
  • 建设一个网站需要的条件怎么做小说推广挣钱
  • 个人网站做微擎流量精灵官网
  • 免费建一个网页的链接廊坊seo
  • 国内 上市网站建设公司html网页制作步骤
  • 互联网营销外包公司百度首页排名优化公司
  • 衡阳电商网站建设百度seo排名培训优化
  • 电商网站建设策划书搜索软件使用排名
  • h5自助建站系统百度新闻排行榜
  • 晚上睡不着看b站正常吗保定网站建设方案优化
  • 做现货值得关注的财经网站山西优化公司
  • seo网站查询属于免费的网络营销方式
  • 门户网站建设情况调研报告百度官网网站登录
  • 58同城石家庄网站建设酒店如何进行网络营销