丑数

<span style="font-size:18px;">我门把只含有因子2,3,5的数称为丑数。求按从小到大排列的第1500个丑数。习惯上,我门把1当作第一个丑数。</span>
<span style="font-size:18px;">假设前i个丑数已经按序排列,现在求第i+1个丑数。很显然,第i+1个丑数为前i个丑数分别乘以2或乘以3或乘以5后大于第i个丑数的最小丑数。假设T2为前i个数乘以2后第一个大于第i个丑数的数,<span style="font-family: Arial, Helvetica, sans-serif;">T3为前i个数乘以3后第一个大于第i个丑数的数,</span><span style="font-family: Arial, Helvetica, sans-serif;">T5为前i个数乘以5后第一个大于第i个丑数的数,那么第i+1个丑数为min(T2*2,T3*3,T5*5).</span></span>

// ConsoleApplication2.cpp : 定义控制台应用程序的入口点。
//丑数

#include "stdafx.h"
#include<iostream>
#include<string>
#include<math.h>
#include<algorithm>
using namespace std;
bool IsUgly(int number){
	while (number % 2 == 0){
		number = number / 2;
	}
	while (number % 3 == 0){
		number = number / 3;
	}
	while (number % 5 == 0){
		number = number / 5;
	}
	if (number == 1)
		return 1;
	else
		return 0;
}
int Min(int number1, int number2, int number3);

int GetUglyNumber_Solution2(int index){
	int *a=new int[index];
	a[0] = 1;
	int i, j;
	int *Mult2 = a;
	int *Mult3 = a;
	int *Mult5 = a;
	for ( i = 1; i < index; i++){
		int min=Min((*Mult2) * 2, (*Mult3) * 3, (*Mult5) * 5);
		a[i] = min;
		for (; (*Mult2) * 2 <= a[i]; Mult2++);
		for (; (*Mult3) * 3 <= a[i]; Mult3++);
		for (; (*Mult5) * 5 <= a[i]; Mult5++);
	}
	int ugly = a[i - 1];
	delete[] a;
	return ugly;

}
int Min(int number1, int number2, int number3){
	int min1 = min(number1, number2);
	return (min1 < number3 ? min1 : number3);

}
void Test(int index, int expected){
	if (GetUglyNumber_Solution2(index) == expected)
		printf("solution2 passed\n");
	else
		printf("solution2 failed\n");

}
int _tmain(int argc, _TCHAR* argv[])
{
	Test(9, 10);
	Test(10, 12);
	Test(11, 15);

	Test(1500, 859963392);
	system("pause");
	return 0;
}
<img src="https://img-blog.csdn.net/20160825205055437?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值