2019_GDUT_新生专题 数论---B Fedya and Maths

B—Fedya and Maths

原题链接:https://vjudge.net/problem/59949/origin

题目大意:

在这里插入图片描述

题目分析:

(1n+2n+3n+4n) mod 5 == (1n mod 5 + 2n mod 5 + 3n mod 5 + 4n mod 5) mod 5
所以运用 费马小定理:p为质数,a不是p的倍数时,ap-1mod p == 1
这里距离 2n mod 5,其他的同理
2n mod 5 == 2[n/4]*4 *2n%4 mod 5 == 1 * 2n%4 mod 5
所以只要求出 n%4
n很大,n可以看出十进制下的数:n == a+b*100,比如:123456== 56+1234*100
这相加的两部分中,第二部分mod 4 结果肯定为0,所以只要求第一部分mod 4,就是n%4的结果。
到这里再使用pow()其实就解决了。

但我多想了一步:n%4的值只有4个:0,1,2,3
所以(10+20%5+30%5+40%5)==4
(11+21%5+31%5+41%5)==0
(12+22%5+32%5+42%5)==0
(13+23%5+33%5+43%5)==0

代码实现:

#include <iostream>
#include <cstdio>

using namespace std;

int main()
{
    char a, b, c;
    int n, ans;
    a = b = '\0';
    while((c = getchar()) != '\n'){
        a = b;
        b = c;
    }
    if(a == '\0'){	//n只有1位数
        n = b - '0';
    }
    else{			//n的最后两位数
        n = (a - '0') * 10 + (b - '0');
    }
    switch(n%4)
    {
        case 0: ans = 4; break;
        case 1:
        case 2:
        case 3: ans = 0; break;
    }
    cout << ans << endl;
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值