Java编程题目-13:Ugly Number

首先是题目要求:
Write a program to check whether a given number is an ugly number.
Ugly numbers are positive numbers whose prime factors only include 2, 3, 5. For example, 6, 8 are ugly while 14 is not ugly since it includes another prime factor 7.
Note that 1 is typically treated as an ugly number.
大概意思就是:把只包含质因子2、3和5的数称作丑数(Ugly Number),给我们一个数,写个方法判断下它是不是丑数。
原题链接:请戳这里

下面是我的代码实现:

public class Solution {
    public boolean isUgly(int num) {
        if(num==1) return true; //题目里说了1作为特色丑数
        if(num<=0) return false; //丑数都是非负的
        if(num==7) return false; 
        int i = 2;
        ArrayList<Integer> list = new ArrayList<Integer>();
        int res = 0;
        while(res==0){
            res = num%i;
            if(res!=0) i++;
            num = num/i;
            list.add(i);
            if(num==1) break;
        }
        for (Integer integer : list) {
            if(integer!=2 && integer!=3 && integer!=5)
                return false;
        }
        return true;
    }
}

上面是我最开始的思路,现在看来很混乱啊,什么乱七八糟的想法,还很麻烦。


下面是过了半天又想到了新的思路:

public class Solution {
    public boolean isUgly(int num) {
        if(num==1) return true;
        if(num<=0) return false;
        while(num>1){
            if(num%2==0){
                num = num/2;
            }else if(num%3==0){
                num = num/3;
            }else if(num%5==0){
                num = num/5;
            }else{
                return false;
            }
        }        
        return true;
    }
}

这个思路就简单清晰了许多,用那个数直接2、3、5轮着除,最后还是除不尽那就必然不是丑数。因为丑数因式分解后因子只能有2、3、5,所以才能这个判断。

前期练习阶段先不考虑代码优化,只要能实现功能,先写出来,以后再慢慢改善。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值