当前位置: 首页 > news >正文

做衣服外贸用什么网站好优化官方网站设计

做衣服外贸用什么网站好,优化官方网站设计,wordpress摘要过滤,学完网站建设再可以学什么选素数 小蓝有一个数 x,每次操作小蓝会选择一个小于 x 的素数 p,然后在 x 成为 p 的倍数前不断将 x 加 1,(如果 x 一开始就是 p 的倍数则 x 不变)。 小乔看到了小蓝进行了 2 次上述操作后得到的结果 n,他想…

选素数

小蓝有一个数 x,每次操作小蓝会选择一个小于 x 的素数 p,然后在 x 成为 p 的倍数前不断将 x 加 1,(如果 x 一开始就是 p 的倍数则 x 不变)。
小乔看到了小蓝进行了 2 次上述操作后得到的结果 n,他想知道 x 在一开始是多少。如果有多种可能,他想知道 x 一开始最小可以是多少,而如果不存在任何解,说明小乔看错了,此时请输出 −1。
输入格式
输入一行包含一个整数 n,表示经过两次操作后 x 的值。
输出格式
输出一行包含一个整数表示 x 的初始值。如果有多个解,输出最小的。如果不存在解,请输出 −1

这个题主要考察质因数分解和质数判断
首先质数的判断,这个太常见了,这里就不多赘述

private static boolean isPrime(int n){if (n<2)return false;if (n==2||n==3)return true;if (n%6!=1&&n%6!=5)return false;for (int i = 5; i*i<= n ; i+=6) {if (n%i==0||n%(i+2)==0){return false;}}return true;}

然后是质因数分解,这里用了 List 集合去装分解出来的质数

private static List<Integer> prime(int n){List<Integer> ans  = new LinkedList<>();for(int i = 2; i <= n/i ; i++){//判断条件用n/i,以防i*i<=n发生溢出int a = 0;//每次循环都要清零while(n % i == 0){n /= i;a++;}if(a > 0)ans.add(i);}//若该数是质数,那么应该将自身(n)也加入if(n > 1) ans.add(n);return ans;}

最后就是根据题意进行模拟,a0→a1→ a2
(依次进行第一次操作、第二次操作)。

import java.util.*;//导入万能类 当然也不是很万能
public class Main {static List<Integer> oList = new LinkedList<>();//需要用到的集合public static void main(String[] args) {//标准输入 一个nScanner sc  = new Scanner(System.in);int n = sc.nextInt();if (isPrime(n)){//如果输入数为质数,那么打印-1。因为我们的n应该是质数的倍数,且必须至少为2倍(题目中说了选择一个小于x的素数p,所以至少是2倍)。System.out.println("-1");}else {oList = prime(n);//对其质因数分解,并用集合装好int minstart = Integer.MAX_VALUE;//定义所求的最小开始的a0,赋值为Integer最大值,为了后面获取最小值for (int i = 0; i < oList.size(); i++) {//遍历质因数集合int last_left = n-oList.get(i);//下面对第一次操作后可能的数组遍历for (int j = last_left+1; j <= n ; j++) {//这里的范围为什么是从last_left+1到n//假设第二次操作选择的是oList.get(i)作为质数,那么第二次操作前的数(a1)不会小于n-oList.get(i)//上次操作前的数字(a1)必然在左边界加1和n之间。(为什么是n?因为n可能本身就是某个质数的倍数,然后这次操作又选了该质数,则n不变)if (isPrime(j)){continue;//跟上面一样,不可能是质数。}List<Integer> temp = prime(j);//继续对上个数进行质因数分解int max = Collections.max(temp);//找出最大的质因数作为第一次操作选择的质数,这样能使起始数字(即a0)尽可能小minstart = Math.min(j-max+1,minstart);//更新维护最小数字}}if (minstart==Integer.MAX_VALUE){System.out.println("-1");}else {System.out.println(minstart);}}}//质数的判断private static boolean isPrime(int n){if (n<2)return false;if (n==2||n==3)return true;if (n%6!=1&&n%6!=5)return false;for (int i = 5; i*i<= n ; i+=6) {if (n%i==0||n%(i+2)==0){return false;}}return true;}//对n进行质因数分解private static List<Integer> prime(int n){List<Integer> ans  = new LinkedList<>();for(int i = 2; i <= n/i ; i++){//判断条件用n/i,以防i*i<=n发生溢出int a = 0;//每次循环都要清零while(n % i == 0){n /= i;a++;}if(a > 0)ans.add(i);}//若该数是质数,那么应该将自身(n)也加入if(n > 1) ans.add(n);return ans;}
}
http://www.yayakq.cn/news/662203/

相关文章:

  • 网站维护费用包括哪些本周热点事件
  • 怎样编辑网站标题做外贸网站卖什么好
  • 郑州航海路网站建设哪些网站可以找到兼职做报表的
  • 网站建设方案范本互动网页设计
  • 河北建设广州分公司网站免费外网
  • 南京cms建站系统软件发布网站源码
  • 网站宣传创意视频企业网站被转做非法用途
  • 40万用户自助建站网站企业建设方案
  • 南宁做网站建设php网站开发实用技术答案
  • 可以做淘宝客的网站soho建网站 必须先注册公司吗
  • 永州做网站费用如何选择网站开发公司
  • 上海建设工程质量监督站网站网站制作对公司的作用
  • 我想给图书网站做代理网站运营周期
  • 怎么用wordpress建电商网站吗国外网站如何搭建网页
  • 怎么关闭自己公司网站眉山做网站
  • 网站空间不足公司加盟代理
  • 网站源码下载以营销推广为主题的方案
  • 西部数码网站管理助手自己如何做网站关键词排名
  • 使用c 语言建设网站优点微信小程序是干什么用的
  • 深圳做微信网站制作网站链接可以自己做吗
  • 网站定制需求变装小说wordpress
  • 三网合一网站建设合同h5游戏大厅
  • 外网如何查看局域网建设的网站网络推广方案ppt
  • 二手房在哪个网站做合同建设银行余额明细查询
  • 网站宽度 自动收缩为什么明明有网却打不开网页
  • 免费网站建设网站优化软件山西seo博客
  • 网站开发遇到的难点做包子网站
  • 网站1g空间多少钱江西建站哪家专业
  • 注册360建筑网平台百度seo优化公司
  • 网站建设公众号开发网页设计与制作考试