BZOJ2299 HAOI2011向量(数论)
生活随笔
收集整理的這篇文章主要介紹了
BZOJ2299 HAOI2011向量(数论)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
設最后的組成為x=x0a+x1b,y=y0a+y1b。那么容易發現x0和y0奇偶性相同、x1和y1奇偶性相同。于是考慮奇偶兩種情況,問題就變為是否存在x和y使ax+by=c,那么其充要條件是gcd(a,b)|c。
#include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> #include<cstring> #include<algorithm> using namespace std; int read() {int x=0,f=1;char c=getchar();while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();return x*f; } int gcd(int n,int m){return m==0?n:gcd(m,n%m);} bool check(int a,int b,long long x,long long y) {if (x&1) return 0;if (y&1) return 0;x>>=1,y>>=1;int n=gcd(a,b);return x%n==0&&y%n==0; } int main() { #ifndef ONLINE_JUDGEfreopen("bzoj2299.in","r",stdin);freopen("bzoj2299.out","w",stdout);const char LL[]="%I64d\n"; #elseconst char LL[]="%lld\n"; #endifint T=read();while (T--){int a=read(),b=read();long long x=read(),y=read();if (check(a,b,x,y)||check(a,b,x-a,y-b)||check(a,b,x-b,y-a)||check(a,b,x-a-b,y-a-b)) printf("Y\n");else printf("N\n");}return 0; }?
轉載于:https://www.cnblogs.com/Gloid/p/9558049.html
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的BZOJ2299 HAOI2011向量(数论)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: BZOJ2169 连边(动态规划)
- 下一篇: 今天俺要说一说工厂方法模式(Factor