求一个整数的因数分解--Java--小白必懂
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | public class OJ_1415 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int num = sc.nextInt(); int sNum = num; splitNum(sNum); } // 求整数的因式分解的方法 public static void splitNum( int num) { if (num == 1 ) { System.out.println(num); } HashMap<Integer, Integer> hap = new HashMap<>(); int kNum = num; for ( int i = 2 ; i <= kNum; ) { if (kNum % i == 0 ) { if (hap.keySet().contains(i)) { hap.put(i, hap.get(i) + 1 ); } else { hap.put(i, 1 ); } kNum = kNum / i; i= 2 ; } else { i++; } } // map中保存了每个因子的出现次数,然后遍历这个hashMap,如果需要从小到大显示还需要排序 // 使用Collections的sort方法对hashMap的key进行排序 Collection<Integer> key = hap.keySet(); List<Integer> lst = new ArrayList<>(key); Collections.sort(lst); StringBuilder sb = new StringBuilder(); for ( int i = 0 ; i < lst.size(); i++) { sb.append( "" +lst.get(i) + "^" + "(" +hap.get(lst.get(i))+ ")" ); } sb.append( "=" + num); System.out.println(sb.toString()); } } |
要求:给定一个整数,求整数的因式分解,要求输出结果按因子由大到小的方式排列输出
例子1:
输入:120
输出:2^(3)3^(1)5^(1)=120
例子2:
输入:6
输出:2^(1)3^(1)=120
本文来自博客园,作者:{Justin_Hu},转载请注明原文链接:{https://www.cnblogs.com/gchenghu/}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?