输出第n个丑数

题目:

  给你一个整数 n,输出第n个丑数。

丑数是指因数只包含2、3、5的正整数。


样例1:
输入:n=10
输出:12
丑数序列:[1,2,3,4,5,6,8,9,10,12],12是第10个丑数。

 样例2:

输入:n=1
输出:1
1通常视为丑数。 


方法 动态规划

首先用vector声明一个存储int数据的容器dp(n),大小为n,已经知道 1通常视为丑数,所以dp[0]=1,dp[n-1]就是我们所找的第n个丑数。

然后,我们再声明3个指针p2、p3、p5,初始时都指向第一个丑数dp[0]。

接下来的步骤是:① p2所指的丑数(p2、p3、p5指着的数必定是丑数)与2相乘,p3指着的丑数与3相乘,p5指着的丑数与5相乘,然后比较这三个数的大小,找到当中最小的积。② 最小的积对应的指针+1,若有两个相同且最小,或三个积相同,那么对应的所有指针都+1。

以下是代码实现:

#include<iostream>
#include<vector>
using namespace std;

int mymin(int a, int b, int c, int& p2, int& p3, int& p5)
{               //p2 p3 p5与乘积 a b c 是一一对应的
	int temp=a>b?b:a;
	temp = temp > c ? c : temp; //找到最小的乘积

	if (temp == a) //判断a是否最小
		p2++;
	if (temp == b) //判断b是否最小
		p3++;
	if (temp == c) //判断c是否最小
		p5++;
	//最小的话,对应指针+1
	return temp;
}

int nthUglyNumber(int n) {
	vector<int> uglys(n);
	uglys[0] = 1;

	int p2 = 0, p3 = 0, p5 = 0; //三个指针;

	for (int i = 1; i < n; i++)
		uglys[i] = mymin(uglys[p2]*2,uglys[p3]*3,uglys[p5]*5,p2,p3,p5);

	return uglys[n - 1];
}

int main(void)
{
	for(int i=1;i<11;i++)
	cout <<"第"<<i<<"个丑数为: "<<nthUglyNumber(i) << endl;

	return 0;
}

输出:

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值