java例题_04 分解质因数

 1 /*4 【程序 4 分解质因数】
 2 题目:将一个大于 2 正整数分解质因数。例如:输入 3, 3=3, 输入 6, 6=2*3,输入 90, 90=2*3*3*5。
 3 程序分析:对 n 进行分解质因数,应先找到一个最小的质数 k,然后按下述步骤完成:
 4 (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
 5 (2)如果 n<>k,但 n 能被 k 整除,则应打印出 k 的值,并用 n 除以 k 的商,作为新的正整数 n,重复执行第
 6 一步。
 7 (3)如果 n 不能被 k 整除,则用 k+1 作为 k 的值,重复执行第一步。
 8 */
 9
10 /*分析:
11  * 1.从键盘输入一个整数n,百度到三种方法,感觉使用scanner类比较方便,没有局限性
12  * 2.用for循环遍历除以2~n,找到第一个能除尽的值a
13  * 3.用n除以a值得到新的n
14  * 4.重复以上过程,直到n=a;
15 */
16
17 //【注】因为最终需要得到所有a的具体值,以此想到数组,学习发现java中的数组和C中的数组声明时有区别
18
19
20
21 package homework;
22
23 import java.util.Scanner;
24
25 public class _04 {
26
27     public static void main(String[] args) {
28
29         System.out.println("请输入一个整数n:");
30         // 从键盘得到一个整数n
31         Scanner scan=new Scanner(System.in);
32         int n=scan.nextInt();
33         int m=n;
34         //声明一个长度为20的数组用来存放因数a的值
35         int a[]=new int[20];
36         //声明一个数组角标
37         int j=0;
38         //遍历2~n的值,用if语句判断呢能否整除
39         for (int i=2; i<=m;) {
40             if(m%i==0) {
41                 a[j]=i;
42                 j++;    //多加了一个
43                 m=m/i;
44             }
45             else {
46                 i++;
47             }
48         }
49         //输出分解后的因式
50         System.out.print(n+","+n+"=");
51         System.out.print(a[0]);
52         for (int i=1; i<=j-1; i++) {       //将多加的减回来
53             System.out.print("*"+a[i]);
54         }
55     }
56
57 }

原文地址:https://www.cnblogs.com/scwyqin/p/12293031.html

时间: 2024-12-18 23:20:51

java例题_04 分解质因数的相关文章

java编程题 --分解质因数

package Solve; import java.util.Scanner; public class Solve { static Scanner scan = new Scanner(System.in); public static void main(String[] args) { System.out.println("请输入一个正整数:"); int num = scan.nextInt(); System.out.print(num + " = "

java分解质因数代码

import java.util.*; class 分解质因数 { static ArrayList<Integer> al; public static void main(String[] args) { al=new ArrayList<Integer>(); fenjie(84729332); System.out.println(al); } public static void fenjie(int x) { if(isPrime(x)) { al.add(x); re

java--编程(分解质因数)

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

java求最大公约数(分解质因数)

下面是四种用java语言编程实现的求最大公约数的方法: package gcd; import java.util.ArrayList; import java.util.List; public class gcd { public static void main(String[] args) { long startTime; long endTime; long durationTime; int[] testArray1 = new int[]{784, 988, 460, 732,

中国MOOC_零基础学Java语言_第7周 函数_1分解质因数

第7周编程题 查看帮助 返回 第7周编程题 依照学术诚信条款,我保证此作业是本人独立完成的. 温馨提示: 1.本次作业属于Online Judge题目,提交后由系统即时判分. 2.学生可以在作业截止时间之前不限次数提交答案,系统将取其中的最高分作为最终成绩. 1 分解质因数(5分) 题目内容: 每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数.比如,6可以被分解为2x3,而24可以被分解为2x2x2x3. 现在,你的程序要读入一个[2,10000

Java实现将一个正整数分解质因数

* 题目:将一个正整数分解质因数.例如:输入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的值,重复执行第一步.  *这个题目很明显是要用递归算法来实现的,打印"*"有些技巧,但也

java分解质因数

1 package test; 2 3 import java.util.Scanner; 4 5 public class Test19 { 6 /** 7 * 分析:对n进行分解质因数,应先找到一个最小的质数k 8 9 * 最小的质数:即“2”.2是最小的质数,即是偶数又是质数,然后按下述步骤完成: 10 11 *(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可. 12 13 *(2)如果n>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重

java 分解质因数 基础增强

题目:将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. 为了熟悉加强基础练习,搞搞经典小demo..话不多说,直接贴代码,看注释.package www.test;import java.util.Scanner; public class Resovle { public static void main(String[] args) { /** 简单分析: * 如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可. 如果n能被k整除,则应打印出k的值,并用n除

Java练习(四)--分解质因数

题目:将一个正整数分解质因数.例如:输入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 Test1 { public void zhi(int n) { Sy