news 2026/5/16 12:43:50

算法题 自除数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法题 自除数

自除数

问题描述

自除数是指可以被它包含的每一位数整除的正整数。
例如,128 是一个自除数,因为128 % 1 == 0128 % 2 == 0128 % 8 == 0

注意:自除数不允许包含 0,因为任何数除以 0 都是未定义的。

给定两个整数leftright,返回[left, right]范围内所有自除数的列表。

示例

输入: left = 1, right = 22 输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22]

算法思路

  1. 遍历[left, right]范围内的每个数字
  2. 对每个数字,提取其每一位数字进行验证
  3. 验证条件:
    • 不能包含数字 0(因为除以 0 未定义)
    • 原数字必须能被每一位数字整除
  4. 如果满足所有条件,则为自除数

代码实现

方法一:逐位验证

importjava.util.*;classSolution{/** * 找出指定范围内所有的自除数 * * @param left 范围左边界(包含) * @param right 范围右边界(包含) * @return 自除数列表 */publicList<Integer>selfDividingNumbers(intleft,intright){List<Integer>result=newArrayList<>();// 遍历给定范围内的每个数字for(intnum=left;num<=right;num++){// 检查当前数字是否为自除数if(isSelfDividing(num)){result.add(num);}}returnresult;}/** * 判断一个数字是否为自除数 * * @param num 待检查的数字 * @return true表示是自除数,false表示不是 */privatebooleanisSelfDividing(intnum){intoriginal=num;// 保存原始数字用于后续的整除判断// 逐位检查数字的每一位while(num>0){intdigit=num%10;// 获取当前数字的最后一位// 如果包含0,则不是自除数// 任何数都不能被0整除(除以0未定义)if(digit==0){returnfalse;}// 原始数字必须能被当前位数字整除if(original%digit!=0){returnfalse;}num/=10;// 去掉最后一位,继续检查下一位}// 所有位都通过检查,是自除数returntrue;}}

方法二:字符串

importjava.util.*;classSolution{/** * 使用字符串判断自除数 * * @param left 范围左边界(包含) * @param right 范围右边界(包含) * @return 自除数列表 */publicList<Integer>selfDividingNumbers(intleft,intright){List<Integer>result=newArrayList<>();for(intnum=left;num<=right;num++){if(isSelfDividingString(num)){result.add(num);}}returnresult;}/** * 使用字符串判断自除数 * * @param num 待检查的数字 * @return true表示是自除数,false表示不是 */privatebooleanisSelfDividingString(intnum){StringnumStr=String.valueOf(num);// 遍历字符串的每个字符for(charc:numStr.toCharArray()){intdigit=c-'0';// 将字符转换为数字// 检查是否包含0或不能整除if(digit==0||num%digit!=0){returnfalse;}}returntrue;}}

算法分析

  • 时间复杂度:O(n × log m)

    • n = right - left + 1(范围内的数字个数)
    • log m = 数字的位数(m 为数字的大小,以10为底的对数)
    • 每个数字需要检查其所有位数
  • 空间复杂度:O(1)(不包括结果列表)

    • 只使用了常数个额外变量

算法过程

输入:left = 1, right = 22

  1. num = 1

    • 位数:1
    • 1 % 1 == 0
  2. num = 2

    • 位数:2
    • 2 % 2 == 0
  3. num = 10

    • 位数:1, 0
    • 包含0
  4. num = 11

    • 位数:1, 1
    • 11 % 1 == 0

最终结果:[1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22]

测试用例

publicstaticvoidmain(String[]args){Solutionsolution=newSolution();// 测试用例1:标准示例System.out.println("Test 1: "+solution.selfDividingNumbers(1,22));// [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22]// 测试用例2:包含10的范围System.out.println("Test 2: "+solution.selfDividingNumbers(10,15));// [11, 12, 15]// 测试用例3:单个数字System.out.println("Test 3: "+solution.selfDividingNumbers(1,1));// [1]// 测试用例4:较大范围System.out.println("Test 4: "+solution.selfDividingNumbers(1,100));// 包含1-9, 11, 12, 15, 22, 24, 33, 36, 44, 48, 55, 66, 77, 88, 99// 测试用例5:包含边界值System.out.println("Test 5: "+solution.selfDividingNumbers(47,85));// [48, 55, 66, 77]// 测试用例6:无自除数的范围System.out.println("Test 6: "+solution.selfDividingNumbers(100,101));// []// 测试用例7:包含2000System.out.println("Test 7: "+solution.selfDividingNumbers(1999,2000));// []}

关键点

  1. 0

    • 自除数绝对不能包含数字0
  2. 原始数字保存

    • 在逐位检查时,必须使用原始数字进行整除运算
  3. 位数提取

    • 使用num % 10获取最后一位
    • 使用num / 10去掉最后一位

常见问题

  1. 为什么不能包含0?

    • 数学上除以0是未定义的操作
    • 即使其他位都能整除,只要包含0就不是自除数
  2. 为什么要保存原始数字?

    • 在逐位提取过程中,原数字会被修改(num /= 10
    • 整除判断必须用完整的原始数字
  3. 单数字(1-9)为什么都是自除数?

    • 任何非零数字都能被自己整除
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 7:33:05

深度解析 Flutter 自定义组件封装:从基础封装到高性能复用

欢迎大家加入[开源鸿蒙跨平台开发者社区](https://openharmonycrossplatform.csdn.net)&#xff0c;一起共建开源鸿蒙跨平台生态。在 Flutter 开发中&#xff0c;“组件化” 是提升开发效率、保证代码可维护性的核心抓手。原生组件虽能满足基础需求&#xff0c;但实际业务中&am…

作者头像 李华
网站建设 2026/5/16 8:57:15

顺序栈的入栈函数

顺序栈的知识&#xff1a; 参考视频 46:31-1:01:06这部分讲了栈的概念&#xff0c;顺序表的初始化&#xff0c;出栈&#xff0c;入栈&#xff0c;获取栈顶元素 https://www.bilibili.com/video/BV1tNpbekEht?t2790.6&p5 笔记&#xff1a; 栈和队列栈&#xff1a;只能…

作者头像 李华
网站建设 2026/5/12 4:12:38

利用清华镜像站高速下载GPT-OSS-20B模型权重文件

利用清华镜像站高速下载GPT-OSS-20B模型权重文件 在大语言模型迅速演进的今天&#xff0c;越来越多的研究者和开发者面临一个现实问题&#xff1a;如何在不依赖昂贵算力集群的前提下&#xff0c;本地部署并高效运行具备专业能力的大模型&#xff1f;答案正逐渐清晰——轻量级开…

作者头像 李华
网站建设 2026/5/13 18:23:09

告别低效推理!vLLM镜像助力企业级LLM生产部署

告别低效推理&#xff01;vLLM镜像助力企业级LLM生产部署 在今天的大模型应用浪潮中&#xff0c;越来越多的企业开始将大语言模型&#xff08;LLM&#xff09;嵌入到智能客服、内容生成、代码辅助等核心业务场景。然而&#xff0c;当理想照进现实——从实验室demo走向高并发、7…

作者头像 李华
网站建设 2026/5/9 23:04:52

英文长字符串不换行?前端开发者必备的CSS断行实战指南

英文长字符串不换行&#xff1f;前端开发者必备的CSS断行实战指南英文长字符串不换行&#xff1f;前端开发者必备的CSS断行实战指南当 URL 像火车一样冲出屏幕浏览器心里的小剧场&#xff1a;为啥不换&#xff1f;word-break 与 overflow-wrap&#xff1a;看似双胞胎&#xff0…

作者头像 李华
网站建设 2026/5/14 4:04:39

HunyuanVideo-Foley模型部署指南:Windows18-HD19环境下的安装包配置

HunyuanVideo-Foley模型部署实践&#xff1a;基于Windows18-HD19环境的完整配置与优化 在短视频创作井喷、影视工业化加速的今天&#xff0c;音效制作正面临前所未有的效率瓶颈。传统流程中&#xff0c;一个10秒的视频可能需要音效师手动匹配数个素材文件&#xff0c;并反复调整…

作者头像 李华