扩展欧几里得以及欧拉

#include<iostream>

#include<algorithm> #include<string> #include<queue> #include<cmath> #include<vector> #include<stdlib.h> #include<iomanip> #include<map> #include<stack> #include<memory.h> using namespace std; typedef long long ll; //解决 ax+by=gcd(a,b) int extend_Euclid(ll a, ll b, int &x, int &y) { int d, int temp; if (b == 0) { x = 1; y = 0; return a; } d = extend_Euclid(b, a%b, x, y); temp = x; x = y; y = temp - a / b*y; return d; } //ax=b(mod n)>>ax-b=ny>>ax+nt=b->d=gcd(a,n)->k=b/d->x=x0*k 一个解 int liner_Euclid(ll a, ll b, int n) { int d, x, y; d = extend_Euclid(a, n, x, y); if (b%d != 0) { return -1; } x = x*b / d; x = (x%n + n) % (n / d); return x; } /*算法导论里说:(还没理解) 方程axºb(mod n)有解(即存在d|b,其中d=gcd(a,n)),x0是该方程的任意一个解,则该方程对模n恰有d个不同的 解,分别为 x(i)=x(0)+i(n/d)(i=1,2,...d). 特别的设e=x0+n,方程ax=b(mod n)的最小整数解x1=e mod (n/d),最大整数解x2=x1+(d-1)*(n/d)。*/ bool mod_lineEuclid(ll a, ll b, ll n) { int d, x, y; d = extend_Euclid(a, n, x, y); if (b%d != 0) { return false;; } x = x*(b/d)%n; for (int i = 0; i <= d; i++) { ll x0 = (x + i*(n / d)) % n; cout << x0 << endl; } ll x1 = (x + n) % (n / d); ll x2 = x1 + (d - 1)*(n / d); cout << x1 << '\t' << x2 << endl; return true; } /*欧拉公式:求一个n 的小于他的质数个数 对于质数p:f(p)=p-1 */ int oular(ll n) { ll ans = n; ll a = n; for (ll i = 2; i*i < a; i++) { if (n%i == 0) { ans = ans / i*(i - 1); while (a%i == 0) { a /= i; } } } if (a > 1)ans = ans / a*(a - 1); return ans; } int main() { }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值