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

企业培训网站郑州北环附近网站建设

企业培训网站,郑州北环附近网站建设,商标注册网站官网,彩票网站是怎么做的ch05 数论 素数筛 目标:筛选出 1 ∼ n 1\sim n 1∼n 范围内的所有素数(质数) 为了让时间复杂度是线性的 O ( n ) O(n) O(n) ,需要保证每个合数只被标记一次,不能重复标记。 欧拉筛的做法是令 x 只被它的最小质因…

ch05 数论

素数筛

目标:筛选出 1 ∼ n 1\sim n 1n 范围内的所有素数(质数)

为了让时间复杂度是线性的 O ( n ) O(n) O(n) ,需要保证每个合数只被标记一次,不能重复标记。

欧拉筛的做法是令 x 只被它的最小质因子 p 1 p_1 p1 乘以 i i i 标记为合数。

为了做到这一点,当 i % p == 0 时,就不用枚举更大的质数了,可以跳出循环。

代码:

const int N = 50000010;
bool isp[N]; // isp[x]=true表示x是质数,false表示不是质数
vector<int> prime; // prime储存质数
void eulerPrime(int n) { // 筛选出1~n范围的所有质数memset(isp, true, sizeof(isp));isp[0] = isp[1] = false;for (int i = 2; i <= n; i++) {if (isp[i]) prime.push_back(i);for (int p : prime) { // 遍历当前筛出的所有质数if (i * p > n) break;isp[i * p] = false; // 数字i*p是合数,p是i*p的最小质因数if (i % p == 0) break; // 保证每个合数只被最小质因子*i标记}}
}

欧拉筛不止可以用来筛素数,也可以在筛素数过程中顺便记录每个数的最小质因子、最小质因子对应的指数等。

模运算定律

加法:(a + b) % m == (a % m + b % m) % m

乘法:(a * b) % m == (a % m) * (b % m) % m

减法:(a − b) % m == (a % m − b % m + m) % m

  • 注意出现负数(减法)的地方,要 + m,避免计算结果为负数

  • 对于要求答案 % m 的题目,通常不能等到输出答案时才 % m,因为计算过程就可能溢出数据范围了,所以要利用上面的模运算定律在计算过程中 % m。

除法:除法没有简单的模运算定律。想要在除法的计算过程中取模,需要使用逆元

指数:

  • 特别注意指数不能直接 % m ,例如要计算 a b % m a^b\%m ab%m ,算成了 a b % m % m a^{b\%m} \%m ab%m%m 就会出错。
  • 对指数取模要用到扩展欧拉定理,不是本节课内容。

快速幂

快速幂是在 O ( log ⁡ b ) O(\log b) O(logb) 的时间复杂度内计算 a b a^b ab 的技巧 。思想是将幂的计算按照指数的二进制表示来分割成更小的任务。

ll fastPow(ll a, ll b, int p) {a %= p;if (b == 0) return 1;ll tmp = fastPow(a, b / 2, p);if (b & 1) return tmp * tmp % p * a % p;return tmp * tmp % p;
}

逆元

除以 x,相当于乘以“x 的乘法逆元”,这样就可以避免除法运算

费马小定理:如果 p 是一个质数,并且 x 不是 p 的倍数,则有 x p − 1 ≡ 1 ( m o d p ) x^{p-1}\equiv 1\pmod p xp11(modp)

代码:

// 返回 x 模 m 意义下的乘法逆元
ll inv(ll x, int m) {if (x % p == 0) return -1; // -1 表示 x 不存在模 m 意义下的乘法逆元return fastPow(x, m - 2, m);
}

由费马小定理求逆元比较方便,也好理解,但有局限性,注意 p 必须是质数

除法取模:计算 a / x % m 可以转换为 a * inv(x, m) % m

http://www.dtcms.com/wzjs/558542.html

相关文章:

  • 网站的前期推广时空网站建设的可行性分析
  • 淘宝内部卷网站怎么做wordpress后台图
  • 彩票网站怎么做赚钱wordpress点击tag跳回首页
  • 网站开发人员工具种类网站建设公司销售招聘
  • 网站建设公司外链怎么做男女做暖暖不要钱的试看网站
  • 企业建站1年网站运营一月多少钱
  • 阿里云网站建设最后什么样子网站在国内服务器在国外
  • 网站投票怎么做制作网站公司合同注意事项
  • 移动网站制作公司网站设计制作开发
  • 杭州seo网站哪家好wordpress展示类主题
  • 广州网站建设与实验seo免费外链工具
  • 建设网站好难重庆网站建设红衫
  • 制作宣传网站有哪些可以充值的网站怎么做
  • 打码网站做的比较好的是哪些flask做大型网站开发
  • 免费的中文logo网站wordpress博客 免费
  • 犀牛云 做网站网页制作代码格式
  • 做ag视频大全网站老吕爱分享 wordpress
  • 自己电脑做网站访问速度做宠物网站赚钱吗
  • 北京网站建设 seo公司哪家好番禺品牌型网站建设
  • 受欢迎的惠州网站建设wordpress解决速度
  • window做网站的软件下载提高seo排名
  • 长沙做一个网站要多少钱做网站的企业
  • 网站建设管理情况报告网站类网站开发源代码
  • 做企业培训的网站免费企业网站建设流程
  • 成都价格网站建设服务公司淘宝网页版电脑版登录淘宝网
  • 武冈市住房和城乡建设局网站免费制作永久企业网站
  • 丹阳网站建设多少钱seo优化 搜 盈seo公司
  • wordpress 站点标题网站代理服务器连接失败
  • 怎么建立一个博客网站吗舆情处置的五个步骤
  • 播州区建设局网站重庆网页制作设计营销