【NOIP普及组】质因数分解

【NOIP普及组】质因数分解

      • C语言代码
      • C++代码
      • Java代码
      • Python代码


💐The Begin💐点点关注,收藏不迷路💐

已知正整数 n 是两个不同的质数的乘积,试求出较大的那个质数。

输入

输入只有一行,包含一个正整数 n。

输出

输出只有一行,包含一个正整数 p,即较大的那个质数。

样例输入

21

样例输出

7

提示

【数据范围】
对于 60%的数据,
6≤n≤1000。
对于 100%的数据,
6≤n≤2∗10^9 。

C语言代码

#include <stdio.h>
#include <math.h>int main() {int n;  // 存储输入的正整数scanf("%d", &n);  // 读取输入的正整数int maxPrime = 0;  // 用于存储较大的质数,初始化为0// 从2开始遍历到n的平方根,因为一个数的因数不会超过它的平方根for (int i = 2; i <= sqrt(n); i++) { if (n % i == 0) {  // 如果i是n的因数int otherFactor = n / i;  // 计算另一个因数// 判断i和另一个因数是否都是质数int isIprime = 1;for (int j = 2; j <= sqrt(i); j++) {if (i % j == 0) {isIprime = 0;break;}}int isOtherFactorPrime = 1;for (int j = 2; j <= sqrt(otherFactor); j++) {if (otherFactor % j == 0) {isOtherFactorPrime = 0;break;}}// 如果i和另一个因数都是质数,更新较大的质数if (isIprime && isOtherFactorPrime) {maxPrime = (i > otherFactor)? i : otherFactor;}}}printf("%d\n", maxPrime);  // 输出较大的质数return 0;
}

C++代码

#include <iostream>
#include <cmath>int main() {int n;  // 存储输入的正整数std::cin >> n;  // 读取输入的正整数int maxPrime = 0;  // 用于存储较大的质数,初始化为0// 从2开始遍历到n的平方根,因为一个数的因数不会超过它的平方根for (int i = 2; i <= std::sqrt(n); i++) { if (n % i == 0) {  // 如果i是n的因数int otherFactor = n / i;  // 计算另一个因数// 判断i和另一个因数是否都是质数bool isIprime = true;for (int j = 2; j <= std::sqrt(i); j++) {if (i % j == 0) {isIprime = false;break;}}bool isOtherFactorPrime = true;for (int j = 2; j <= std::sqrt(otherFactor); j++) {if (otherFactor % j == 0) {isOtherFactorPrime = false;break;}}// 如果i和另一个因数都是质数,更新较大的质数if (isIprime && isOtherFactorPrime) {maxPrime = (i > otherFactor)? i : otherFactor;}}}std::cout << maxPrime << std::endl;  // 输出较大的质数return 0;
}

Java代码

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();  // 读取输入的正整数int maxPrime = 0;  // 用于存储较大的质数,初始化为0// 从2开始遍历到n的平方根,因为一个数的因数不会超过它的平方根for (int i = 2; i <= Math.sqrt(n); i++) { if (n % i == 0) {  // 如果i是n的因数int otherFactor = n / i;  // 计算另一个因数// 判断i和另一个因数是否都是质数boolean isIprime = true;for (int j = 2; j <= Math.sqrt(i); j++) {if (i % j == 0) {isIprime = false;break;}}boolean isOtherFactorPrime = true;for (int j = 2; j <= Math.sqrt(otherFactor); j++) {if (otherFactor % j == 0) {isOtherFactorPrime = false;break;}}// 如果i和另一个因数都是质数,更新较大的质数if (isIprime && isOtherFactorPrime) {maxPrime = (i > otherFactor)? i : otherFactor;}}}System.out.println(maxPrime);  // 输出较大的质数scanner.close();}
}

Python代码

import mathn = int(input())  # 读取输入的正整数maxPrime = 0  # 用于存储较大的质数,初始化为0# 从2开始遍历到n的平方根,因为一个数的因数不会超过它的平方根
for i in range(2, int(math.sqrt(n)) + 1): if n % i == 0:  # 如果i是n的因数otherFactor = n // i  # 计算另一个因数# 判断i和另一个因数是否都是质数isIprime = all(i % j!= 0 for j in range(2, int(math.sqrt(i)) + 1))isOtherFactorPrime = all(otherFactor % j!= 0 for j in range(2, int(math.sqrt(otherFactor)) + 1))# 如果i和另一个因数都是质数,更新较大的质数if isIprime and isOtherFactorPrime:maxPrime = max(i, otherFactor)print(maxPrime)  # 输出较大的质数

在这里插入图片描述


💐The End💐点点关注,收藏不迷路💐

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/885177.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024软件测试面试热点问题

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 大厂面试热点问题 1、测试人员需要何时参加需求分析&#xff1f; 如果条件循序 原则上来说 是越早介入需求分析越好 因为测试人员对需求理解越深刻 对测试工…

qt QTextStream详解

1、概述 QTextStream类是Qt框架中用于处理文本输入输出的类。它提供了一种方便的方式&#xff0c;可以从各种QIODevice&#xff08;如QFile、QBuffer、QTcpSocket等&#xff09;中读取文本数据&#xff0c;或者将文本数据写入这些设备中。QTextStream能够自动处理字符编码的转…

【LeetCode】【算法】287. 寻找重复数

LeetCode 287. 寻找重复数 题目描述 给定一个包含 n 1 个整数的数组 nums &#xff0c;其数字都在 [1, n] 范围内&#xff08;包括 1 和 n&#xff09;&#xff0c;可知至少存在一个重复的整数。 假设 nums 只有 一个重复的整数 &#xff0c;返回 这个重复的数 。 你设计的解…

React05 样式控制 classnames工具优化类名控制

样式控制 & classnames工具优化类名控制 样式控制1. 行内样式控制2. 外部样式控制 classnames工具优化类名控制 样式控制 1. 行内样式控制 //定义样式 const style {color: red,fontSize: 30px }function App() {return (<div className"App">{/* 行内样…

题解:P11248 [GESP202409 七级] 矩阵移动

题目传送门 题目大意 给出一个 n n n 行 m m m 列的只包含 0、1、? 的矩阵&#xff0c;你可以选择至多 x x x 个 ? 改成 1。 设得分为经过的 1 的数量&#xff0c;求从矩阵的 ( 1 , 1 ) (1,1) (1,1) 开始&#xff0c;每次只能向右或向下移动&#xff0c;走到 ( n , m…

Webpack性能优化指南:从构建到部署的全方位策略

文章目录 1、webpack的优化-OneOf2、webpack的优化-Include/Exclude3、webpack优化-SourceMap4、webpack的优化-Babel缓存5、wenbpack的优化-resolve配置6、构建结果分析 webpack优化在现代前端开发中&#xff0c;Webpack已成为模块打包器的事实标准&#xff0c;它通过将项目中…

[ DOS 命令基础 4 ] DOS 命令命令详解-端口进程相关命令

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

飞书API-获取tenant_access_token

1.在飞书工作台创建应用&#xff0c;跳到开发者后台&#xff0c;选创建企业自建应用 2.设置并发布应用 必须要发布应用才可以开始使用了&#xff01;&#xff01;&#xff01; 3.调用获取token的API 参考链接&#xff1a; 开发文档 - 飞书开放平台https://open.feishu.cn/do…

linux 安装anaconda3

1.下载 使用repo镜像网址下载对应安装包 右击获取下载地址&#xff0c;使用终端下载 wget https://repo.anaconda.com/archive/Anaconda3-2024.02-1-Linux-x86_64.sh2.安装 使用以下命令可直接指定位置 bash Anaconda3-2024.02-1-Linux-x86_64.sh -b -p /home/anaconda3也…

LabVIEW编程过程中为什么会出现bug?

在LabVIEW编程过程中&#xff0c;Bug的产生往往源自多方面原因。以下从具体的案例角度分析一些常见的Bug成因和调试方法&#xff0c;以便更好地理解和预防这些问题。 ​ 1. 数据流错误 案例&#xff1a;在一个LabVIEW程序中&#xff0c;多个计算节点依赖相同的输入数据&#…

【自用】fastapi 学习记录 --请求和参数部分

fastai个人学习笔记 一、模块化结构框架 设置了默认请求头shop之后就无需再app0x里接口函数前全部写上/shop/xxx&#xff0c;或者/user/xxx&#xff0c;他会同意添加~如果都写了就会出现以下的情况&#xff08;重复shop&#xff09;&#xff1a; 二、请求与响应 关于参数&a…

若依入门案例

若依&#xff08;RuoYi&#xff09;框架是一个基于Java的开源企业级快速开发框架&#xff0c;主要用于构建信息管理系统。它结合了多种前端和后端技术&#xff0c;提供了高效的开发工具&#xff0c;并具备以下主要功能&#xff1a; 一、后端功能 技术选型&#xff1a;若依后端…

【Web前端】OOP编程范式

面向对象编程&#xff08;Object-Oriented Programming&#xff0c;简称 OOP&#xff09;是一种程序设计思想&#xff0c;它通过将程序视为一组相互作用的对象来设计程序。OOP 提出了一些重要的基本概念&#xff0c;包括类与实例、继承和封装。面向对象编程将系统视为由多个对象…

Mac解决 zsh: command not found: ll

Mac解决 zsh: command not found: ll 文章目录 Mac解决 zsh: command not found: ll解决方法 解决方法 1.打开bash_profile 配置文件vim ~/.bash_profile2.在文件中添加配置&#xff1a;alias llls -alF键盘按下 I 键进入编辑模式3. alias llls -alF添加完配置后&#xff0c;按…

JavaScript 变量声明

const 和 let 都是在 JavaScript ES6 中引入的变量声明方式&#xff0c;它们之间的主要区别在于 是否允许重新赋值 和 作用域。 1. 是否可以重新赋值 let&#xff1a;声明的变量可以在后续代码中被重新赋值。const&#xff1a;声明的变量不能被重新赋值。声明时必须初始化&am…

JavaAPI(1)

Java的API&#xff08;1&#xff09; 一、Math的API 是一个帮助我们进行数学计算的工具类私有化构造方法&#xff0c;所有的方法都是静态的&#xff08;可以直接通过类名.调用&#xff09; 平方根&#xff1a;Math.sqrt()立方根&#xff1a;Math.cbrt() 示例&#xff1a; p…

UI界面设计入门:打造卓越用户体验

互联网的迅猛发展催生了众多相关职业&#xff0c;其中UI界面设计师成为互联网行业的关键角色之一。UI界面设计无处不在&#xff0c;影响着网站、应用程序以及其他数字平台上的按钮、菜单布局、色彩搭配和字体排版等。UI设计不仅仅是字体、色彩和导航栏的组合&#xff0c;它的意…

python查询日志,并组装sql,修复缺失的数据

前言 由于mysql链接超时波动&#xff0c;导致数据缺失&#xff0c;需要根据日志填补数据 流程 获取确实数据的订单列表 搜索日志&#xff0c;获取请求日志 根据请求日志拼装sql 打印sql供修复数据 代码 因为我们日志打印的有问题&#xff0c;所以这里用字符串截取获取入…

利用Stable Diffusion技术,StableVision能够自动生成高质量、高分辨率的图像,满足用户对于图像素材的多样化需求。

1.产品介绍 产品介绍方案 产品名称: StableVision 图像管理分析系统 主要功能: 高精度图像生成智能分类与检索多维度数据分析定制化模板与导出功能介绍: 高精度图像生成: 具体作用:利用Stable Diffusion技术,StableVision能够自动生成高质量、高分辨率的图像,满足用户…

用户信息管理系统烟草种植用户基于SpringBootSSM框架

目录 一. 系统目标 二 需求分析 2.1 功能描述 2.1.1 用户管理 2.1.2 管理员功能 2.1.3 角色与权限管理 2.1.4 详细功能描述 2.1.5安全与权限控制功能 2.1.6系统维护与扩展功能 2.2. 非功能需求 2.3用户角色 2.4技术描述 三、数据库设计 3.1数据库需求分析 3.2数…