URAL 1204 中国剩余定理

简介:

题意:给出一个n n为两个素数的乘积,让求满足方程 x*x=x ( mod n ) 且x<n的解。

给上面等式变形有x*(x-1)=0 ( mod p*q ) 则有 x = 0 ( mod p) x = 1 ( mod q ) 或者 x = 1( mod p) x = 0 ( mod q ),由于p,q,互素,所以可以用中国剩余定理求出最小的正整数解。

 

#include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
#include<set>
using namespace std;
#define maxn 100000
void exgcd(long long a,long long b,long long &d,long long &x,long long &y)
{
    if(b==0)
    {
        x=1,y=0,d=a;
        return;
    }
    exgcd(b,a%b,d,x,y);
    long long temp=x;
    x=y,y=temp-(a/b)*y;
}
long long m[5],a[5],n;
int china(int r)
{
    long long i,mi,x0,y0,d,ans=0;
    for(int i=0; i<r; i++)
    {
        mi=n/m[i];
        exgcd(mi,m[i],d,x0,y0);
        ans=(ans+mi*x0*a[i])%n;
    }
    if(ans<0) ans+=n;
    return ans;
}
bool isprime[maxn];
int prime[maxn],nprime;
void getprime()
{
    memset(isprime,1,sizeof(isprime));
    long long i,j;
    nprime=0;
    for(i=2; i<maxn; i++)
        if(isprime[i])
        {
            prime[nprime++]=i;
            for(j=i*i; j<maxn; j+=i) isprime[j]=0;
        }
}
int main()
{
    getprime();
    int t;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d",&n);
        a[0]=0,a[1]=1;
        int l=(int)sqrt(n*1.0);
        for(int i=0; prime[i]<=l; i++)
            if(n%prime[i]==0) m[0]=prime[i],m[1]=n/prime[i];
        int ans1=china(2),ans2;
        swap(m[0],m[1]);
        ans2=china(2);
        if(ans1>ans2) swap(ans1,ans2);
        printf("0 1 %d %d\n",ans1,ans2);
    }
    return 0;
}

目录
相关文章
|
1月前
lanqiao oj 1121 蓝桥公园(floyd)
lanqiao oj 1121 蓝桥公园(floyd)
41 0
|
5月前
|
Java 程序员
程序员必知:URAL1513.LemonTale(简单的递推)
程序员必知:URAL1513.LemonTale(简单的递推)
24 0
华为机试HJ72:百钱买百鸡问题
华为机试HJ72:百钱买百鸡问题
114 0
|
算法
华为机试HJ76:尼科彻斯定理
华为机试HJ76:尼科彻斯定理
忆pta水题
本题要求编写程序,先将输入的一系列整数中的最小值与第一个数交换,然后将最大值与最后一个数交换,最后输出交换后的序列。 注意:题目保证最大和最小值都是唯一的。 输入格式: 输入在第一行中给出一个正整数N(≤10),第二行给出N个整数,数字间以空格分隔。 输出格式: 在一行中顺序输出交换后的序列,每个整数后跟一个空格。 输入样例: 5 8 2 5 1 4 结尾无空行 输出样例: 1 2 5 4 8 
HDU-1370,Biorhythms(中国剩余定理)
本题主要就是应用中国剩余定理。
|
Java
HDOJ/HDU 5686 Problem B(斐波拉契+大数~)
HDOJ/HDU 5686 Problem B(斐波拉契+大数~)
102 0
|
Java
HDOJ/HDU 1865 1sting(斐波拉契+大数~)
HDOJ/HDU 1865 1sting(斐波拉契+大数~)
101 0
|
人工智能 网络架构
Codeforces 839D Winter is here【数学:容斥原理】
D. Winter is here time limit per test:3 seconds memory limit per test:256 megabytes input:standard input output:standard out...
1068 0
|
机器学习/深度学习
洛谷 P2742 [USACO5.1]圈奶牛Fencing the Cows
题目描述 农夫约翰想要建造一个围栏用来围住他的奶牛,可是他资金匮乏。他建造的围栏必须包括他的奶牛喜欢吃草的所有地点。对于给出的这些地点的坐标,计算最短的能够围住这些点的围栏的长度。 输入输出格式 输入格式:   输入数据的第一行包括一个整数 N。N(0
997 0