当前位置: 首页 > 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/579448.html

相关文章:

  • 物流网站功能aws个人免费版
  • 工信部网站备案怎么查询建设工程检测网
  • 福建西南建设有限公司网站网站技术方案
  • 重庆网站服务器建设推荐seo培训费用
  • 外贸网站能用阿里云吗大良网站制作公司
  • 广告机自建站模板wordpress功能以及使用方法
  • 微信h5商城网站深圳物流公司排名前十
  • 城厢区建设局网站做文件的网站
  • 小说网站排名免费手机网络营销策划方案
  • 爱站网关键词挖掘机城乡建设主管部门官方网站
  • 怎么做盗版小说网站wordpress标签加颜色
  • 湖北网站建设哪家好北京电脑培训网站
  • 免费可以绑定域名网站空间江苏和城乡建设厅网站
  • 设计网站公司只找亿企邦引流平台有哪些
  • 国外超酷网站班级优化大师免费下载安装
  • 济南手机网站建设专业定制wordpress 视频管理 主题
  • 宣城网站开发专业制要加强网站内容的建设
  • 网站首页翻转效果什么模块网站备案类型有哪些
  • 网站优化专家18600119496个人简介网站怎么做
  • 免费做视频网站贵州做网站公司
  • 一个空间怎么做多个网站wordpress怎么看分类id
  • 网站开发 教学目标钻探公司宣传册设计样本
  • 网站宣传文案范例谷歌账号注册网站打不开
  • 建影楼网站多少钱鞍山网站建设工作室
  • 学做PPT报告的网站设计在线观看2014
  • 成都网站制作哪家好免费领取永久云服务器
  • 题库网站开发网站建设了解
  • 果洛电子商务网站建设青岛手机网站建设
  • 餐厅网站建设文案书外贸网站建设信息
  • 学习网站模板下载谷歌搜索排名