A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© losttemp 中级黑马   /  2016-5-20 22:43  /  351 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

/*将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5
程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,
作为新的正整数n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。


*/
public class Test17 {
        public static void main(String[] args) {
        int n=100;
        fenjie(n);
       
        }
        public static void fenjie(int n){
                System.out.print(n+"=");  //如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,
                for (int i = 2; i <n+1 ; i++) {
                        while(n%i==0&&n!=i){
                                n/=i;
                                System.out.print(i+"*");
                        }
                        if(n==i){
                                System.out.println(i);//如果这个质数恰等于n,
                                                                                                //则说明分解质因数的过程已经结束,打印出即可。
                                break;
                        }
                }
               
        }

}

评分

参与人数 1黑马币 +20 收起 理由
ck1993 + 20 很给力!

查看全部评分

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马