质因数分解

质因数  就是一个数的约数,并且是质数。

比如8=2×2×2,2就是8的质因数;

12=2×2×3,2和3就是12的质因数。

把一个式子以12=2×2×3的形式表示,叫做分解质因数

import java.sql.SQLSyntaxErrorException;
import java.util.*;

import static java.lang.Math.abs;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        Map<Integer,Integer> map = primeFactor(n);
        StringBuilder sb = new StringBuilder();
        for(Map.Entry<Integer,Integer> entry : map.entrySet()){
            int k = entry.getKey();
            int v = entry.getValue();
            for(int i =0;i<v;i++){
                sb.append("*"+k);
            }
        }
        if(sb.length()!=0)
        System.out.println(n+"的质因素分解为:"+sb.substring(1));
        else{
            System.out.println(n+"没有质因数分解");
        }
    }
    public static Map<Integer,Integer> primeFactor(int num){
        Map<Integer,Integer>map = new HashMap<>();
        int temp = num;
        for(int i = 2;i<=num;i++){
            if(isPrime(i)){
                while(num%i ==0){
                    map.put(i,map.getOrDefault(i,0)+1);
                    num/=i;
                }
            }
        }
        return map;
    }
    public static boolean isPrime(int num){
        if(num == 1)return false;
        if(num == 2) return true;
        if(num%2==0)return false;
        for(int i = 3;i<=Math.sqrt(num);i++){
            if(num % i ==0){
                return false;
            }
        }
        return true;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值