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

数论1.01

欧几里得(GCD,exGCD)

1.两个数除以最大公约数的结果互为质数

2.欧几里得算法(辗转相除法)求最大公约数

设a,b,c是不全为0的整数,满足1存在整数q,  a=bq+c,,那么(a,b)=(b,c)

其中c就等a%b

时间复杂度是log的

如果a*m=b*n(a|b*n==m)并且a和b互质,那么a就能整除b*n(其实是a能整除n);

0和任何一个数的最大公约数等于该数本身

至于为什么是下面这个代码咋这么求的:

我以我以及的理解写一遍

第一次:ax+by=gcd;

第二次:bx+(a%b)y=gcd

而a%b=a-a/b*b;

所以b*x+(a-a/b*b)*y=gcd;

bx+ay-a/b*b*y=gcd

ay+b*(x-a/b*y)=gcd;

两个红色字体相比不难看出对应的x,y是谁(从后往前推)

x=y,  y=x-a/b*y

如果ax+by=gcd

b=0,那么gcd=a,所以x=1,y=0;

#include<iostream>
#include<cstdio>
#include<cmath>using namespace std;int exgcd(int a,int b,int &x,int &y)//扩展欧几里得算法
{if(b==0){x=1;y=0;return a;  //到达递归边界开始向上一层返回}int r=exgcd(b,a%b,x,y);int temp=y;    //把x y变成上一层的y=x-(a/b)*y;x=temp;return r;     //得到a b的最大公因数
}

整数分解:

埃氏筛:O(nlog(log(n)))

用质数把质数的倍数筛掉

欧拉筛:O(n)

每个合数只需要被其最小的质因子筛掉

const int maxn = 101;   // 表长
int prime[maxn], pNum = 0;    // prime记录素数,pNum记录素数个数 
bool p[maxn] = {false};        // p记录当前数是否被筛去void eulerSieve(int n)    // 查找记录2-n的素数
{for (int i = 2; i <= n; i++){if (p[i] == false)  // 如果未被筛过,则为素数prime[pNum++] = i;for (j = 0; j < pNum; j++){if (i * prime[j] > n)      // 当要标记的合数超出范围时跳出break;p[i * prime[j]] = true;     // 将已经记录的素数的倍数进行标记if (i % prime[j] == 0)      //关键步骤break;}}
}

详细解释看这个:欧拉筛详解-CSDN博客挺详细的。

http://www.xdnf.cn/news/16556.html

相关文章:

  • 【实时Linux实战系列】在实时应用中进行负载均衡
  • Python day27
  • 【硬件】LVGL
  • 时序数据基座升维:Apache IoTDB 以“端边云AI一体化”重构工业智能决策
  • Java 大视界 -- 基于 Java 的大数据实时流处理在智能电网分布式能源接入与电网稳定性保障中的应用(368)
  • 基于黑马教程——微服务架构解析(二)
  • OpenI x SCNet “智能超算”创新应用挑战赛:实践阶段1和阶段2 部署Deepseek推理模型
  • 图片格式转换
  • AR技术赋能工业设备维护:效率与智能的飞跃
  • 【数据结构初阶】--二叉树(三)
  • 使用signal信号机制 + backtrace函数打印出程序崩溃后的堆栈信息
  • Flutter在购物场景中BLoC的应用
  • MySQL面试题及详细答案 155道(001-020)
  • 无人机气动设计模块解析
  • 微信小程序点击输入框时,顶部导航栏被遮挡问题如何解决?
  • 秩为1的矩阵的特征和性质
  • 【数据库】时序数据库选型指南:从大数据视角看IoTDB的核心优势
  • <PLC><西门子><modbusTCP>在西门子S7-1200系列PLC中,如何设置modbusTCP通讯?
  • 语音识别指标计算 WER
  • Java-泛型类的定义与使用
  • 24. 了解过 webp 吗
  • 如何进行DAP-seq的数据挖掘,筛选验证位点
  • Django 视图详解(View):处理请求与返回响应的核心
  • CenterOS8.5三台机器配置互信
  • 图解MySQL-小林code笔记
  • 排水管网实时监测筑牢城市安全防线
  • 本地大语言模型部署指南
  • Dify 工作流深度解析与实战指南
  • 重复文件清理工具,附免费链接
  • RWA 正当红,是 DeFi 的终点、拐点,还是新起点?