石家庄市40中举办第30届戏曲合唱比赛
石家庄市第四十中学戏曲合唱比赛现场(央广网发石家庄市第四十中学供图)5月26日晚,河北省石家庄市第四十
有物不知其数,三三数之剩二,五五数之剩三,七七数之剩二。问物几何?
【资料图】
该问题出自《孙子算经》,具体问题的解答口诀由明朝数学家程大位在《算法统宗》中给出:
三人同行七十希,五树梅花廿一支,七子团圆正半月,除百零五便得知。
\(2 \times 70 + 3 \times 21 + 2 \times 15 = 233 = 2 \times 105 + 23\),故答案为 \(23\)。
定义中国剩余定理 (Chinese Remainder Theorem, CRT) 可求解如下形式的一元线性同余方程组(其中 \(n_1, n_2, \cdots, n_k\) 两两互质):
\[\begin{cases}x \bmod p_1 = a_1\\x \bmod p_2 = a_2\\\cdots\\x \bmod p_n = a_n\\\end{cases}\]过程对于方程
\[\begin{cases}x \bmod p_1 = a_1\\x \bmod p_2 = a_2\\\end{cases}\]我们可以得知 \(x = k_1 p_1 + a_1 = k_2 p_2 + a_2\),进而推出 \(k_1 p_1 - k_2 p_2 = a_2 - a_1\)我们观察这个式子,是不是跟 \(xa + yg = g\) 很像?我们可以用扩展欧几里得算法来做。扩展欧几里得算法代码
int exgcd(int a, int b, int &x, int &y) { if (!b) { x = 1, y = 0; return a; } int xp, yp; int g = exgcd(b, a % b, xp, yp); x = yp, y = xp - yp * (a / b); return g;}
中国剩余定理代码
void solve(int p1, int a1, int p2, int a2, int &p, int &a) {// x % p1 = a1// x % p2 = a2// x % p = a// x = k1 * p1 + a1 = k2 * p2 + a2// k1 * p1 - k2 * p2 = a2 - a1 int g, k1, k2; g = exgcd(p1, p2, k1, k2);// k1 * p1 + k2 * p2 = g k2 = -k2;// k1 * p1 - k2 * p2 = g if ((a2 - a1) % g != 0) { p = -1, a = -1; } else { int k = (a2 - a1) / g; k1 = k1 * k, k2 = k2 * k; // k1 * p1 - k2 * p2 = a2 - a1 int x = k1 * p1 + a1; p = p1 / g * p2; a = (x % p + p) % p; }}
通过观察,你会发现,这种解法不需要 \(p_1 \perp p_2\),因此扩展中国剩余定理也是这个解法,这是一种通解。
题目【模板】扩展中国剩余定理(EXCRT)卡 __int128
。
#include using namespace std;typedef long long ll;const int N = 1e5 + 5;int n;ll a[N], b[N];ll qtimes(ll x, ll y, ll p) {if (y == 0) return 0;ll z = qtimes(x, y / 2, p);z = (z + z) % p;if (y & 1) {z = (1ll * z + x) % p;}return z;}ll exgcd(ll a, ll b, ll &x, ll &y) {if (b == 0) {x = 1, y = 0;return a;}ll xp, yp;ll g = exgcd(b, a % b, xp, yp);x = yp, y = xp - yp * (a / b);return g;}void CRT(ll p1, ll a1, ll p2, ll a2, ll &p, ll &a) {ll g, k1, k2;g = exgcd(p1, p2, k1, k2);k2 = -k2;if ((a2 - a1) % g != 0) {p = -1, a = -1;}else {ll k = (a2 - a1) / g;__int128 K1 = k1 * k, K2 = k2 * k;__int128 x = K1 * p1 + a1;p = p1 / g * p2;a = (x % p + p) % p;}}int main() {ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);cin >> n;for (int i = 1; i <= n; ++ i) {cin >> a[i] >> b[i];}ll mod = a[1], rest = b[1];for (int i = 2; i <= n; ++ i) {CRT(mod, rest, a[i], b[i], mod, rest);}cout << rest % mod << "\n";return 0;}
【模板】中国剩余定理(CRT)/ 曹冲养猪
#include using namespace std;typedef long long ll;const int N = 1e5 + 5;int n;ll a[N], b[N];ll qtimes(ll x, ll y, ll p) {if (y == 0) return 0;ll z = qtimes(x, y / 2, p);z = (z + z) % p;if (y & 1) {z = (1ll * z + x) % p;}return z;}ll exgcd(ll a, ll b, ll &x, ll &y) {if (b == 0) {x = 1, y = 0;return a;}ll xp, yp;ll g = exgcd(b, a % b, xp, yp);x = yp, y = xp - yp * (a / b);return g;}void CRT(ll p1, ll a1, ll p2, ll a2, ll &p, ll &a) {ll g, k1, k2;g = exgcd(p1, p2, k1, k2);k2 = -k2;if ((a2 - a1) % g != 0) {p = -1, a = -1;}else {ll k = (a2 - a1) / g;__int128 K1 = k1 * k, K2 = k2 * k;__int128 x = K1 * p1 + a1;p = p1 / g * p2;a = (x % p + p) % p;}}int main() {ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);cin >> n;for (int i = 1; i <= n; ++ i) {cin >> a[i] >> b[i];}ll mod = a[1], rest = b[1];for (int i = 2; i <= n; ++ i) {CRT(mod, rest, a[i], b[i], mod, rest);}cout << rest % mod << "\n";return 0;}
关键词:
石家庄市第四十中学戏曲合唱比赛现场(央广网发石家庄市第四十中学供图)5月26日晚,河北省石家庄市第四十
近日,南部战区空军航空兵某旅组织开展实战化飞行训练,进一步锤炼部队打赢本领。看数架战鹰呼啸升空,直刺
据央视新闻:德国外交部官员当地时间5月27日对媒体证实,将于近日从俄罗斯撤回逾百名政府工作人员,其中包
直播吧5月28日讯 今天,NBA季后赛东决G6,凯尔特人104-103战胜热火,大比分打成3-3平。至此,今年季后赛凯
泡发木耳时最好选用15~25℃的温水,大概浸泡6个小时左右,这样让木耳吸足水分,吃起来的口感也比较好。若
1、流行歌曲《说好的幸福呢》钢琴简谱《说好的幸福呢》是周杰伦演唱的一首歌曲,由方文山作词,周杰伦作曲
今天请看《观海·暖一周》第四十期该出手时“救”出手,青岛人好样的!这反应,真快!这身影,真美!5月19
先把速冻汤圆拿出来,在室温下中放着,等水烧开以后再放汤圆进去,等汤圆浮起来,加一次冷水,再浮起来就可
江苏100处“乐享园林”项目名单公布,口袋公园占约70%,满足市民“出门见园、推窗见绿”的愿望,实现全龄友
中央纪委国家监委网站讯据重庆市纪委监委消息:重庆市政府文史研究馆党组书记王合清涉嫌严重违纪违法,目前
5月25日,参与“‘转作风 看发展’媒体基层调研行”活动的多家中央驻滇媒体和省、市主流媒体记者走进江川
邢台电动自行车新规有哪些?电动车上路需要遵循哪些新条例?本文整理了相关信息,详见正文。
中国女篮欧洲拉练次战:16分惨负西班牙吞首败3人上双高颂14分,高颂,西班牙,王思雨,杨力维,李月汝,中国女篮,
1、香格里拉的由来 "香格里拉 "一词,源于藏经中的香巴拉王国,在藏传佛教的发展史上,其一直作为 "净王 "
柳沁雯5 27黄金周评:短线交易耐得住“寂寞”守得住盈利,下周走势解析时间轻轻流逝,转眼又到了周末的日子
1、一、组织机构以项目经理为首,由项目副经理、专业安全工程师,各施工队及各施工班组等各方面的管理人员
1、《宇宙大帝传》是南国短歌所著的一本小说。2、类型是科幻幻想。3、在起点中文网连载。文章到此就分享结
导读莫斯科在广播,斯科在广播的简介很多人还不知道,现在让我们一起来看看吧!1、《莫斯科在广播》是由鲍
相信大家对家用漏电保护开关的型号及规格介绍,家用漏电开关一般用多少a的的问题都很疑惑,这个问题很多人
1、先了解一下他的情况吧,看看他是不是有喜欢的女孩了,不管有没有,都要发动攻击,爱情是不能让步的。2、
今天小红来为大家带来的是牛逼克拉斯原版,牛逼克拉斯,让我们一起往下看看吧!1、这个句式太龌龊,这个表
小伙伴们好,带大家回顾下巴特勒G5贡献14分5篮板5助攻斯波要让巴特勒进入到他的舒适区会在下一场比赛中改善
今天来聊聊关于基槽,什么是基槽的文章,现在就为大家来简单介绍下基槽,什么是基槽,希望对各位小伙伴们有
27日08时-11时,阜阳、六安、合肥、滁州、安庆、铜陵、芜湖、马鞍山、池州、宣城、黄山等地有降水,共有64
华声在线5月27日讯(全媒体记者潘显璇通讯员向怡)2023年3月1日起,长沙禁止超标电动车上路行驶,违规车辆