算法竞赛进阶指南0x33同余
定义
如果整数a,b除以正整数m的余数相同,那么a,b模m同余 。
知识点








拓展欧几里得算法
代码
#include <bits/stdc++.h>
using namespace std;
int exgcd(int a, int b, int &x, int &y)
{
if(b==0)
{
x = 1;
y = 0;
return a;
}
int d = exgcd(b, a%b, x, y);//代表答案
int z = x;
x = y;
y = z-(a/b)*y;
return d;
}
int main()
{
int a, b;
cin >> a >> b;
int x, y;
int ans = exgcd(a, b, x, y);
printf("%d %d %d", ans, x, y);
return 0;
}
AcWing97. 约数之和

一看:显然不能使用暴力。
一提到数论,应该下意识想起分解质因数。
#include <bits/stdc++.h>
using namespace std;
const int mod = 9901;
int p[50];
int c[50];
int cnt = 0;//指示总共有多少个素数
void devide(int n)
{
for(int i = 2; (long long)i*i <= n; i++)
{
if(n % i == 0)
{
p[++cnt] = i;
c[cnt] = 0;
while(n % i==0)
{
c[cnt]++;
n /= i;
}
}
}
if(n > 1)
{
p[++cnt] = n;
c[cnt] = 1;
}
}
int ksm(int a, int b, int pp)
{
int ans = 1 % pp;
int tmp = a % pp;
while(b)
{
if(b&1) ans = (long long)ans * tmp % pp;
tmp = (long long)tmp * tmp % pp;
b >>= 1;
}
return ans%pp;
}
int cal(int i)
{
int ans = 1;
int pri = p[i];
int num = c[i];
if((pri-1) % mod == 0)
{
return (num+1)% mod;
}
int fenzi = (ksm(pri, num+1, mod)+mod-1)%mod;
if((pri-1) % mod != 0)
{
int niyuan = ksm(pri-1, mod-2, mod);
fenzi = (long long)fenzi * niyuan % mod;
}
return fenzi;
}
int main()
{
int ans = 1;
int A, B;
cin >> A >> B;
if(A == 0) //注意需要进行特殊判断
{
printf("0");
return 0;
}
devide(A);
for(int i = 1; i <= cnt; i++)
{
c[i] = B * c[i];
}
for(int i = 1; i <= cnt; i++)
{
int res = cal(i);
ans = (long long)res * ans % mod;
}
cout << ans;
return 0;
}
AcWing203. 同余方程

AcWing204. 表达整数的奇怪方式

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll exgcd(ll a, ll b, ll &x, ll &y)
{
if(b==0)
{
x = 1;
y = 0;
return a;
}
ll d = exgcd(b, a%b, x, y);
ll z = x;
x = y;
y = z-(a/b)*y;
return d;
}
int main()
{
int n;
cin >> n;//由于每一个值都是从之前递推得来的,所以我特殊构造第一个值
ll ans = 0;
ll lcm = 0;
ll a, m;
scanf("%lld%lld", &m, &a);
ans = a;
lcm = m;
n--;
bool flag = true;
while(n--)
{
ll x, y;
scanf("%lld%lld", &m, &a);
ll d = exgcd(lcm, m, x, y);
a = (a - ans%m + m)%m;
if(a%d!=0)
{
flag = false;
break;
}//注意:x并不是同余方程的解(还要算一下比例)
ll k = x*(a/d)%m;
//ans += k*lcm;
//x = (x%m+m)%m;ll k = x*(a/d)%m;
ans += k*lcm;
//ans += x*lcm;
lcm = lcm/d*m;////必须在更新完成lcm之后才可以进行
ans = (ans%lcm+lcm)%lcm;
}
if(flag)
{
printf("%lld", ans);
}
else
{
printf("-1");
}
return 0;
}
算法竞赛进阶指南0x33同余的更多相关文章
- 《算法竞赛进阶指南》0x10 基本数据结构 Hash
Hash的基本知识 字符串hash算法将字符串看成p进制数字,再将结果mod q例如:abcabcdefg 将字母转换位数字(1231234567)=(1*p9+2*p8+3*p7+1*p6+2*p5 ...
- 《算法竞赛进阶指南》1.4Hash
137. 雪花雪花雪花 有N片雪花,每片雪花由六个角组成,每个角都有长度. 第i片雪花六个角的长度从某个角开始顺时针依次记为ai,1,ai,2,-,ai,6. 因为雪花的形状是封闭的环形,所以从任何一 ...
- bzoj 1787 && bzoj 1832: [Ahoi2008]Meet 紧急集合(倍增LCA)算法竞赛进阶指南
题目描述 原题连接 Y岛风景美丽宜人,气候温和,物产丰富. Y岛上有N个城市(编号\(1,2,-,N\)),有\(N-1\)条城市间的道路连接着它们. 每一条道路都连接某两个城市. 幸运的是,小可可通 ...
- POJ1639 算法竞赛进阶指南 野餐规划
题目描述 原题链接 一群小丑演员,以其出色的柔术表演,可以无限量的钻进同一辆汽车中,而闻名世界. 现在他们想要去公园玩耍,但是他们的经费非常紧缺. 他们将乘车前往公园,为了减少花费,他们决定选择一种合 ...
- 算法竞赛进阶指南 0x00 基本算法
放在原来这个地方不太方便,影响阅读体验.为了读者能更好的刷题,另起一篇随笔. 0x00 基本算法 0x01 位运算 [题目][64位整数乘法] 知识点:快速幂思想的灵活运用 [题目][最短Hamilt ...
- 算法竞赛进阶指南--快速幂,求a^b mod p
// 快速幂,求a^b mod p int power(int a, int b, int p) { int ans = 1; for (; b; b >>= 1) { if (b &am ...
- 算法竞赛进阶指南0x14 Hash
组成部分: 哈希函数: 链表 AcWing137. 雪花雪花雪花 因为所需要数据量过于大,所以只能以O(n)的复杂度. 所以不可能在实现的过程中一一顺时针逆时针进行比较,所以采用一种合适的数据结构. ...
- 《算法竞赛进阶指南》1.6Trie
142. 前缀统计 给定N个字符串S1,S2-SN,接下来进行M次询问,每次询问给定一个字符串T,求S1-SN中有多少个字符串是T的前缀. 输入字符串的总长度不超过106,仅包含小写字母. 输入格式 ...
- 《算法竞赛进阶指南》 1 (P4) a^b 快速幂
快速幂 #include<cstdio> #include<cmath> #include<iostream> using namespace std; long ...
随机推荐
- Erdos-Renyi随机图的生成方式及其特性
1 随机图生成简介 1.1 \(G_{np}\)和\(G_{nm}\) 以下是我学习<CS224W:Machine Learning With Graphs>[1]中随机图生成部分的笔记, ...
- axios源码解析 - 请求方法的别名实现
axios中的创建请求方式很多,比如axios(url),axios.get(url),axios.post(url),axios.delete(url),方便快捷的api设计让axios火得一塌糊涂 ...
- Node.js + TypeScript + ESM +HotReload ( TypeScript 类型的 Node.js 项目从 CommJS 转为 ESM 的步骤)
当前 Node.js 版本:v16.14.0 当前 TypeScript 版本:^4.6.3 步骤 安装必要的依赖 yarn add -D typescript ts-node @tsconfig/n ...
- react 疑问集锦
在 setState 后未 re-render function component 初始化调用接口
- 【多线程】创建线程方式二:实现Runnable接口
创建线程方式二:实现Runnable接口 代码示例: /** * @Description 实现Runnable接口,重写run方法,执行线程需要丢入Runnable接口实现类,调用start方法 * ...
- awk应用场景之过滤举例
以/etc/passwd举例,passwd文本 [root@196 tmp]# cat /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bi ...
- Spring Boot配置全局异常捕获
1 SpringBoot配置全局的异常捕获 项目的说明 配置thymeleaf作为视图模板 ExceptionController.java模拟测试用 MyAjaxExceptionHandler.j ...
- 关于我学git这档子事
创建本地分支并切换到该分支 git checkout -b *** 相当于如下2个命令: git branch *** git checkout *** 推送本地开发分支到远程开发分支 git pus ...
- python封装发送邮件类
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart i ...
- ACW:831. KMP字符串
感觉这道题非常有意思,学的过程中觉得及难,学完之后觉得及简单,看y总的视频没有看懂...,因此自己找了一篇博文理解并完成题目. import java.io.*; /** * @author admi ...