标签:
Write a program to find the n
-th ugly number.
Ugly numbers are positive numbers whose prime factors only include 2, 3, 5
. For example, 1, 2, 3, 4, 5, 6, 8, 9, 10, 12
is the sequence of the first 10
ugly numbers.
Note that 1
is typically treated as an ugly number.
Hint:
isUgly
for every number until you reach the nth one. Most numbers are not ugly. Try to focus your effort on generating only the ugly ones. int get_min(int a, int b, int c){ int min = (a - b) > 0 ? b : a; return (min - c) > 0 ? c : min; } int nthUglyNumber(int n) { int *ugly = malloc(n * sizeof(int)); int factor2 = 2, factor3 = 3, factor5 = 5; int index2 = 0, index3 = 0, index5 = 0; int minNum = 0; ugly[0] = 1; for(int i = 1; i < n; i++){ minNum = get_min(factor2, factor3, factor5); ugly[i] = minNum; if(factor2 == minNum) factor2 = 2 * ugly[++index2]; if(factor3 == minNum) factor3 = 3 * ugly[++index3]; if(factor5 == minNum) factor5 = 5 * ugly[++index5]; } return ugly[n - 1]; }
标签:
原文地址:http://www.cnblogs.com/dylqt/p/5063304.html