丑数
2016-08-25 20:39
113 查看
<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;elsereturn 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");elseprintf("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="http://img.blog.csdn.net/20160825205055437?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
相关文章推荐
- 穷?富?
- Nginx反向代理和负载均衡
- Ubuntu 入坑第一天
- BLE广播数据的抓包解析
- (零)ELK学习之ELK安装配置
- Adapter
- Mysql学习总结(34)——Mysql 彻底解决中文乱码的问题
- Struts2入门
- Mysql学习总结(34)——Mysql 彻底解决中文乱码的问题
- noip 瑞士轮 - 归并
- JavaScript中this指向的简单理解
- epoll实现压测工具
- PHP运行模式(cgi,fast-cgi,cli,web模块模式)
- 数据结构考研时间复杂度分析学习
- How Hypernetes Brings Multi-tenancy to Microservice Architectures
- 14. Longest Common Prefix
- Python 深拷贝和浅拷贝
- ViewPagerIndicator导航栏
- OC-类与对象
- linux 遭遇SIGPIPE信号,导致进程退出的问题