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

中国剩余定理和扩展中国剩余定理(模板)

给你一元线性同余方程组,如下:

其中,当 n_{1} , n_{2} , ... , n_{k} 两两互质的话就是中国剩余定理 , 不互质的话就是扩展中国剩余定理。

给出中国剩余定理的计算过程和扩展中国剩余定理的推理过程:

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int m;
int a[15],b[15];
int exgcd(int a,int b,int &x,int &y){if(b==0){x=1,y=0;return a;}int gcd=exgcd(b,a%b,y,x);y-=(a/b)*x;return gcd;
}
int CRT(){int p=1,ans=0;for(int i=1;i<=m;i++) p*=a[i];for(int i=1;i<=m;i++){int c=p/a[i],x=0,y=0;exgcd(c,a[i],x,y);ans=(ans+b[i]*c*x%p)%p;}return (ans%p+p)%p;
}
signed main()
{IOScin >> m;for(int i=1;i<=m;i++) cin >> a[i];// b[i]是模数 for(int i=1;i<=m;i++) cin >> b[i];// a[i]是余数cout << CRT() << endl;return 0;
}

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int m,f=0;
int a[15],b[15];
int exgcd(int a,int b,int &x,int &y){if(b==0){x=1,y=0;return a;}int gcd=exgcd(b,a%b,y,x);y-=(a/b)*x;return gcd;
}
int CRT(){int p=a[1],r=b[1],x=0,y=0;for(int i=2;i<=m;i++){int c=b[i]-r,gcd=exgcd(p,a[i],x,y);if(c%gcd){f=1;return 0;}int tmp=c/gcd*x,t=a[i]/gcd;tmp=(tmp%t+t)%t;r+=p*tmp;p=a[i]/gcd*p;}return r;
}
signed main()
{IOScin >> m;int num=1;for(int i=1;i<=m;i++) cin >> a[i];//模数 for(int i=1;i<=m;i++) cin >> b[i];//余数if(f) cout << -1 << endl;// 无解 else cout << CRT() << endl;// 有解 return 0;
}


http://www.mrgr.cn/news/20323.html

相关文章:

  • vTESTstudio系列13--vTESTstudio中的动态函数库介绍3
  • 安卓版Infuse来了 打造自己的影视墙
  • MMSegmentation测试Segformer
  • modelsim 关闭 warning 的方法
  • Java企业电子招投标系统:Spring Cloud微服务架构-强化企业招采竞争力:电子化招投标平台助力效率与成本控制-支持二次开发
  • 查看当前主机的硬盘是固态硬盘还是机械硬盘
  • TMGM:美国贸易逆差扩大将对第三季度GDP增长产生压力
  • 0.3 学习Stm32经历过的磨难
  • ROG STRIX Z790-E GAMING WIFI II
  • 【C语言】---- 复合数据类型之联合体(Union)
  • 【PostgreSQL教程】PostgreSQL 高级篇之 TRANSACTION(事务)
  • 体育数据API纳米足球数据API:足球数据接口文档API示例⑥
  • python socket TCP/UDP/MULTICAST 收发示例
  • Scratch在线玩:我的世界中文版
  • 云微客短视频矩阵系统多账号解析,打造流量新高地!
  • CSS选择器:一文带你区分CSS中的伪类和伪元素!
  • 微型丝杆工艺流程!
  • 如何选择适合的继电器测试负载箱?
  • c++ string中append/push_back/insert的区别以及erase/pop_back的区别
  • 外包干了2个月,技术退步明显了...