zoukankan      html  css  js  c++  java
  • 力扣(LeetCode)728. 自除数

    自除数 是指可以被它包含的每一位数除尽的数。

    例如,128 是一个自除数,因为 128 % 1 == 0,128 % 2 == 0,128 % 8 == 0。

    还有,自除数不允许包含 0 。

    给定上边界和下边界数字,输出一个列表,列表的元素是边界(含边界)内所有的自除数。

    示例 1:

    输入:
    上边界left = 1, 下边界right = 22
    输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22]
    注意:

    每个输入参数的边界满足 1 <= left <= right <= 10000。

    思路 使用String.valueOf(int).contains("0") 来判断数字是否0

    或者在获取数字每一位的时候进行数字0的判断

    Java版

    class Solution {
        public List<Integer> selfDividingNumbers(int left, int right) {
            List<Integer> list = new LinkedList<>();
            for(int i=left;i<=right;i++) {
                if(!String.valueOf(i).contains("0")) {//数字不包含0
                    int temp = i;
                    boolean flag = true;
                    while(temp>0 && flag) {
                        int num = temp % 10;
                        if(i%num==0) {
                            temp = temp/10; 
                        }else {
                           flag = false; 
                        }
                    }
                    if(flag) {
                        list.add(i);
                    }
                }
            }
            return list;
            
        }
    }
    
    class Solution {
        public List<Integer> selfDividingNumbers(int left, int right) {
            List<Integer> list = new LinkedList<>();
            for(int i=left;i<=right;i++) {
                    int temp = i;
                    boolean flag = true;
                    while(temp>0 && flag) {
                        int num = temp % 10;
                        if(num==0) {//数字包含数字0
                            flag=false;
                        }else if(i%num==0) {//该位数字可被除尽
                            temp = temp/10; 
                        }else {//该位数字不可被除尽
                           flag = false; 
                        }
                    }
                    if(flag) {
                        list.add(i);
                    }
            }
            return list;
            
        }
    }
    

    运行结果

  • 相关阅读:
    C++Primer中文版(第4版)第五章习题答案
    C++Primer中文版(第4版)第四章习题答案
    利用矩阵奇异值分解对图像进行压缩
    利用奇异值分解压缩图像
    程序莫名其妙地老死
    图像边沿平滑处理的matlab实现
    Zend Server搭建网站备注
    利用矩阵的n次方求图的连通性
    matlab增加数组元素的效率分析
    PHP语法总结
  • 原文地址:https://www.cnblogs.com/lick468/p/10668910.html
Copyright © 2011-2022 走看看