输入一个整数,输出该整数(包含该整数)以下所有的质数,Java示例

本文介绍了一个使用Java编写的简单质数生成器程序。该程序利用双重循环和条件判断,从2到指定数值范围内找出所有质数,并将其打印出来。通过用户输入确定查找范围,适合初学者理解质数概念及编程实现。
import java.util.*;

public class test {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        if (scanner.hasNext()){
            int a = scanner.nextInt();
            printSushu(a);
        }
    }
    public static void printSushu(int n){
        for (int i=2;i<=n;i++){
        	//定义一个flag
            boolean flag= true;
            for(int j=2;j<i-1;j++){
            	/**
            	 *抛开1和它本身,除以2到它-1之间的所有数,如果有余数为0,
            	 *则直接跳出本次循环
            	 */
                if(i%j == 0){
                    flag= false;
                    break;
                }
            }
            if (flag){
                System.out.print(i);//输出所有的质数
            }
        }
    }
}

在C++中,要输入一个整数并找出它的所有素数因子,你可以编写一个程序,首先接收用户输入的数字,然后分解这个数字成质因数。以下是简单的步骤: 1. 定义一个函数来检查是否是素数。因为我们需要判断的是因子,可以只检查到数字开方即可。 2. 使用一个循环遍历从2开始直到输入整数的平方根的所有数,看它能否整除输入的数。 3. 如果能整除,说明找到了一个因子,记录下来,并继续除以这个因子,直到无法再整除为止。 4. 继续查找下一个因子,直到找到所有的因子。 下面是一个简单的示例代码片段: ```cpp #include <iostream> #include <vector> // 检查是否为素数 bool isPrime(int num) { if (num <= 1) return false; for (int i = 2; i * i <= num; ++i) if (num % i == 0) return false; return true; } // 找出所有素数因子 std::vector<int> primeFactors(int num) { std::vector<int> factors; for (int i = 2; i <= num; ++i) { while (num % i == 0 && isPrime(i)) { // 如果i是因子且是素数 factors.push_back(i); num /= i; } } if (num > 1) factors.push_back(num); // 若剩余部分是质数,则添加 return factors; } int main() { int input; std::cout << "请输入一个整数: "; std::cin >> input; std::vector<int> result = primeFactors(input); if (result.empty()) { std::cout << "输入的数是素数。\n"; } else { std::cout << "输入的数 " << input << " 的素数因子有: "; for (const auto& factor : result) { std::cout << factor << " "; } } return 0; } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值