算法竞赛进阶指南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 ...
随机推荐
- 谁动了我的主机? 之活用History命令
点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! Linux系统下可通过history命令查看用户所有的历 ...
- 软件项目管理 ——1.2.PMBOK与软件项目管理知识体系
软件项目管理 --1.2.PMBOK与软件项目管理知识体系 归档于软件项目管理初级学习路线 第一章 软件项目管理基本概念 <初级学习路线合集 > @ 目录 软件项目管理 --1.2.PMB ...
- 渗透:wesside-ng
WEP自动破解工具wesside-ng wesside-ng是aircrack-ng套件提供的一个概念验证工具.该工具可以自动扫描无线网络,发现WEP加密的AP.然后,尝试关联该AP.关联成功后,它会 ...
- 1.Spring开发环境搭建——intellj
1.在intellj中新建项目,选择JDK版本(1.8版本) 2.选择相关信息填写,注意Java版本要和上面步骤选择的版本一致. 3.选择springBoot版本,勾选Spring Web选项. 4. ...
- 594. Longest Harmonious Subsequence - LeetCode
Question 594. Longest Harmonious Subsequence Solution 题目大意:找一个最长子序列,要求子序列中最大值和最小值的差是1. 思路:构造一个map,保存 ...
- 个人冲刺(四)——体温上报app(二阶段)
冲刺任务:完成用户注册功能和数据库类 RegisterActivity.java package com.example.helloworld; import android.content.Inte ...
- 安装Squid到CentOS(YUM)
运行环境 系统版本:CentOS Linux release 7.3.1611 (Core) 软件版本:无 硬件要求:无 安装过程 1.关闭防火墙和SeLinux [root@localhost ~] ...
- ESP8266远程控制电子门
ESP8266远程控制电子门 最前面介绍: 这是一个使用ESP8266 联网控制继电器,实现手机远程控制电子门,打开关闭,开关一次的物联网联手小项目 附git地址:https://github.com ...
- ERP采购收货在标准成本和移动平均价下的差别
欢迎关注微信公众号:iERPer (ERP咨询顾问之家) ERP系统在处理主要的采购流程有: 下采购合同->下采购订单->收货->发票校验->付款(财务) 其中 收货和发票校验 ...
- Apache Shiro反序列化漏洞(Shiro550)
1.漏洞原理: Shiro 是 Java 的一个安全框架,执行身份验证.授权.密码.会话管理 shiro默认使用了CookieRememberMeManager,其处理cookie的流程是:得到rem ...