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

【蓝桥云课】求正整数的约数个数

一、求正整数n的约数个数

方法一(常用算法):从1到n逐一判断其能否整除n,若能整除n即为n的约数,否则不是n的约数。
方法二:从1到n\sqrt{n}n逐一判断是否为n的约数,当n\sqrt{n}n为n的约数时,个数加1;其余情况为约数时,个数加2。
方法三(素因子法):
对于任意整数n(n≥1),都可以写成唯一素因子乘积的形式,即 :
n=∏i=1kpiai=p1a1∗p2a2∗...∗pkakn=\prod_{i=1}^{k}p_i^{a_i}=p_1^{a_1}*p_2^{a_2}*...*p_k^{a_k}n=i=1kpiai=p1a1p2a2...pkak
,则n的约数个数为(a1+1)∗(a2+1)∗...∗(ak+1)(a_1+1)*(a_2+1)*...*(a_k+1)(a1+1)(a2+1)...(ak+1)

例如:36=2×2×3×3=22×322^2×3^222×32,36的约数个数为(2+1)×(2+1)=9
24=2×2×2×3=23×312^3×3^123×31,24的约数个数为(3+1)×(1+1)=8

import java.util.Scanner;public class FacOfNum {public static void main(String[] args) {Scanner sc = new Scanner(System.in);while(sc.hasNext()) {int n = sc.nextInt();System.out.printf("%d的约数有%d个\n",n,f1(n));System.out.printf("%d的约数有%d个\n",n,f2(n));System.out.printf("%d的约数有%d个\n",n,syz(n));}}/*方法一:从1到n逐一遍历判断*/public static int f1(int n) {int cnt = 0;for(int i=1;i<=n;i++) {if(n%i==0) cnt++;}return cnt;}/*方法二:从1到√n逐一遍历判断*/public static int f2(int n) {int cnt = 0;for(int i=1;i*i<=n;i++) {if(n%i==0) {if(i*i==n) cnt++;else cnt+=2;}}return cnt;}/*方法三:素因子的方法*/public static int syz(int n) {int cnt = 1;int bak = n;for(int i=2;i*i<=bak;i++) {int num = 0;while(bak%i==0) {num++;bak=bak/i;}cnt =cnt*(num+1);}if(bak>1) cnt=cnt*(1+1);//n本身为素数的情况return cnt;}
}

二、100!约数的个数

方法:采用素因子的方法统计

import java.util.Scanner;public class Fac100 {public static void main(String[] args) {int n = 100;System.out.println(facofn(n));}public static long facofn(int n) {int[] prime = new int[n+1];//prime[i]表示素数i这个因子出现的个数for(int i=2;i<=n;i++) {int bak = i;for(int j=2;j*j<=bak;j++) {while(bak%j==0) {prime[j]++;//当前bak是能整除j,有素因子j,prime[j]计数器+1bak=bak/j;}}if(bak>1) prime[bak]++;}long ans = 1;for(int i=2;i<=n;i++) ans=ans*(prime[i]+1);return ans;}
}
http://www.lryc.cn/news/9384.html

相关文章:

  • 刷题记录: wannafly25 E 牛客NC19469 01串 [线段树维护动态dp]
  • 懂九转大肠的微软New Bing 内测申请教程
  • WRAN翻译
  • ROS学习笔记——第二章 ROS通信机制
  • MacOS Pytorch 机器学习环境搭建
  • 项目——博客系统
  • PHP(14)会话技术
  • 对JAVA 中“指针“理解
  • 功率放大器在MEMS微结构模态测试研究中的应用
  • 【算法基础】字典树(Trie树)
  • MyBatis 插件 + 注解轻松实现数据脱敏
  • MySQL优化篇-MySQL压力测试
  • CF43A Football 题解
  • Nginx常用命令及具体应用(Linux系统)
  • 从零实现Web服务器(三):日志优化,压力测试,实战接收HTTP请求,实战响应HTTP请求
  • MFC入门
  • 1、H5+CSS面试题
  • 亚马逊云科技重磅发布《亚马逊云科技汽车行业解决方案》
  • Springboot扩展点之FactoryBean
  • 新库上线 | CnOpenDataA股上市公司交易所监管措施数据
  • 同步辐射XAFS表征方法的应用场景分析
  • 06 antdesign react Anchor 不同页面之间实现锚点
  • mysql调优-内存缓冲池
  • 【LeetCode】每日一题(5)
  • 输入任意多个整数, 把这些数据保存到文件data.txt中.(按ctrl + z)
  • Mysql数据库的时间(3)一如何用函数插入时间
  • 关于eval函数(将JSON格式的字符串转换成JSON格式对象)
  • 2023最强软件测试面试题,精选100 道,内附答案版,冲刺金3银4
  • 一文搞懂Docker容器里进程的 pid 是如何申请出来的?
  • 若依框架如何新增自定义主题风格