题目:
给你一个整数 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;
}
输出: