HDU1573 一元线性同余方程组

简介:

这题很水啊 就是求解一元线性方程组的解 然后问在n的范围内解的个数 很正常的一道题

竟然在输入上 WA了无数次 这个就有点惨了 这个同余方程的解是按照最小公倍数的往上

循环的 然后再注意一下求出的解为0的边界问题就可以了

#include <iostream>
#include<cstdio>
#include<cstring>
using namespace std;
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 gcd(long long a,long long b)
{
    if(b==0)
        return a;
    return gcd(b,a%b);
}
int main()
{
    long long a[15],b[15],m,n,t,a1,r1,a2,r2,c,d,x,y,gc,a0,b0;
    cin>>t;
    while(t--)
    {
        bool flag=0;
        gc=1;
        cin>>n>>m;
        for(int i=0; i<m; i++)
            cin>>b[i],gc=gc/gcd(gc,b[i])*b[i];
        for(int i=0; i<m; i++)
            cin>>a[i];
        r1=a[0];
        a1=b[0];
        for(int i=1; i<m; i++)
        {
            a2=b[i],r2=a[i];
            a0=a1,b0=a2,c=r2-r1;
            exgcd(a0,b0,d,x,y);
            if(c%d)
            {
                flag=1;
                break;
            }
            long long t=b0/d;
            x=(x*(c/d)%t+t)%t;
            r1=r1+a1*x;
            a1=a1*(a2/d);
        }
        if(flag)
        {
            printf("0\n");
            continue;
        }
        long long ans=0;
        if(r1<=n)
            ans=1+(n-r1)/gc;
        if(ans&&r1==0)
            ans--;
        printf("%lld\n",ans);
    }
    return 0;
}


目录
相关文章
|
3月前
子串分值和(蓝桥杯C组)
子串分值和(蓝桥杯C组)
17 0
|
7月前
|
机器学习/深度学习 人工智能
P1012 [NOIP1998 提高组] 拼数(比较特殊的排序问题)
P1012 [NOIP1998 提高组] 拼数(比较特殊的排序问题)
46 0
|
8月前
|
人工智能 索引
洛谷P1005 [NOIP2007 提高组] 矩阵取数游戏
洛谷P1005 [NOIP2007 提高组] 矩阵取数游戏
|
9月前
|
机器学习/深度学习 iOS开发 Windows
P2671 [NOIP2015 普及组] 求和(前缀和)
P2671 [NOIP2015 普及组] 求和(前缀和)
103 0
|
10月前
|
C++
【C++题解】NOIP2015提高组 - 跳石头
【C++题解】NOIP2015提高组 - 跳石头
77 0
|
11月前
|
存储 算法 C++
C++/PTA 组最大数
设有n个正整数,将他们连接成一排,组成一个最大的多位整数。 如:n=3时,3个整数13,312,343连成的最大整数为34331213。
81 0
2014年蓝桥杯c/c++ c组 神奇算式
2014年蓝桥杯c/c++ c组 神奇算式
2016年省赛真题c/c++ c组 第七题 寒假作业 全排列+check+筛选条件
2016年省赛真题c/c++ c组 第七题 寒假作业 全排列+check+筛选条件
2015年蓝桥杯 c/c++组 立方尾不变
2015年蓝桥杯 c/c++组 立方尾不变
2015年蓝桥杯 c/c++组 立方尾不变