码迷,mamicode.com
首页 > 其他好文 > 详细

剑指offer(二十八)之丑数

时间:2016-05-22 12:37:04      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:

题目描述
把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。

思路分析:

1.首先,丑数都是由前5个丑数1,2,3,4,5乘以因子2,3,5才得到的。

2.这里将得到的丑数都存放在数组中。分析一下得到第6个丑数的过程,其他丑数类比。

3.1 将前5个丑数乘以2,然后与第5个丑数进行比较,找出第一个乘以2大于第5个丑数的丑数,将其放在min2中。

3.2 将前5个丑数乘以3,然后与第5个丑数进行比较,找出第一个乘以3大于第5个丑数的丑数,将其放在min3中。

3.3 将前5个丑数乘以5,然后与第5个丑数进行比较,找出第一个乘以5大于第5个丑数的丑数,将其放在min5中。

4.经过上述,第6个丑数必然是min2,min3,min5中最小的那个丑数。比较这三个数,就可以得到第6个丑数。

代码:

public class Solution {
    public int GetUglyNumber_Solution(int index) {
        if(index<=0){
            return 0;
        }
        if(index<=5){
            return index;
        }
        int []arrays=new int[index];
        arrays[0]=1;
        arrays[1]=2;
        arrays[2]=3;
        arrays[3]=4;
        arrays[4]=5;
        int min=0,temp=0;
        int min2=0,min3=0,min5=0;
        for(int i=5;i<index;i++)
        {
            for(int j=0;j<i;j++)
            {
                temp=arrays[j]*2;
           		if(temp>arrays[i-1])
                {
                    min2=temp;
                    break;
                }
            }
            for(int k=0;k<i;k++)
            {
                temp=arrays[k]*3;
           		if(temp>arrays[i-1])
                {
                    min3=temp;
                    break;
                }
            }
            for(int z=0;z<i;z++)
            {
                temp=arrays[z]*5;
           		if(temp>arrays[i-1])
                {
                    min5=temp;
                    break;
                }
            }
            min=min2>min3?(min3>min5?min5:min3):(min2>min5?min5:min2);
            arrays[i]=min;
        }
        return arrays[index-1];
    }
}



剑指offer(二十八)之丑数

标签:

原文地址:http://blog.csdn.net/baidu_21578557/article/details/51464713

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!