解法:直接上模版。
扩展欧几里德的模版:
?
typedef long long LL;
LL ex_gcd(LL a,LL b,LL &x,LL &y)
{
if(b==0)
{
x=1;
y=0;
return a;
}
LL d=ex_gcd(b,a%b,x,y);
LL t=x;
x=y;
y=t-a/b*y;
return d;
}
求解一元线性同余方程组模版:
?
?
LL solve(LL n)
{
LL a1,r1,a2,r2;
LL a,b,c,r,x,y;
bool ifhave=true;
scanf("%lld%lld",&a1,&r1);
for(LL i=1;i
题目: poj 2891 Strange Way to Express Integers
代码:
?
#include
#include
#include
using namespace std; typedef long long LL; LL ex_gcd(LL a,LL b,LL &x,LL &y) { if(b==0) { x=1; y=0; return a; } LL d=ex_gcd(b,a%b,x,y); LL t=x; x=y; y=t-a/b*y; return d; } LL solve(LL n) { LL a1,r1,a2,r2; LL a,b,c,r,x,y; bool ifhave=true; scanf("%lld%lld",&a1,&r1); for(LL i=1;i
>n) { cout<
?
?