1222 Wolf and Rabbit

原帖:http://blog.sina.com.cn/s/blog_64e467d60100zzr1.html

该题是要求判断出是否能通过约瑟夫环的数数方式将所有的点都数出来,结论很简单,就是判定总人数和跳跃人数是否互质,如果最大公约数是一的话,那么输出NO,否则输出YES。证明如下:

  设在N个点的圈中,按每数M个标记一下,那么能够把所有的点遍历到即要满足在循环完一圈后,新的起点一定要在1-M中的任何一点出现一次,这个不难理解吧。那么问题就转化为能否遍历1-M中所有的点,依次如此进行下去,当发现不能满足小区间的要求时,那么其父层亦不能满足要求。那么每次起点的偏移量是否有规律呢?答案是有的,以初始的N和M为例,每次的偏移量是 N%M( 假设N> M反之交换位置 ),也即取余的一个过程,那么接下来的新的N就是M,M也就变成了 N%M, 即 N2<-- M1; M2<-- N1% M1;我们设想当N 不为1,而偏移量M又已经为0,那么整个样例也就不可能做到一一查询了。 哦哦,这就是 闻名遐迩的 gcd。

代码如下:

 

#include <stdio.h> 

   

int gcd( int x, int y ) 

{ 

    int temp; 

    if( x< y ) 

    { 

        temp= x; 

        x= y; 

        y= temp; 

    } 

    while( y ) 

    { 

        int c= y; 

        y= x% y; 

        x= c; 

    } 

    return x; 

} 

   

int main(  ) 

{ 

    int T; 

    scanf( "%d", &T ); 

    while( T-- ) 

    { 

        int x, y; 

        scanf( "%d %d", &x, &y ); 

        puts( gcd( x, y )== 1? "NO": "YES" ); 

    } 

} 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值