P3414 SAC#1 - 组合数 题解

https://www.luogu.org/problemnew/show/P3414(题目传送)

这道题提醒大家一定要认真审题。看清楚后发现n的数据范围稍微小于long long类型的范围(看不清被0吓到的估计都去写近百行高精度和运算符重载了吧。。。),又知道关于组合数的

一个定理:

    卢卡斯定理:(求解C(n,m)%p)C(n,m)%p=C(n/p,m/p)*C(n%p,m%p)%p

一些公式:

 

 这样,解题的核心就是求2^(n-1),这里可以用快速幂来做。

AC代码:

#include<iostream>
#include<cstdio>
using namespace std;
const long long p=6662333;
long long ksm(long long a,long long b)
{
    long long ans=1,c=a;
    while(b)
    {
        if(b&1) ans=ans*a%p;
        a=a*a%p;
        b>>=1;
    }
    return ans;
}
int main()
{
    long long n;
    cin>>n;
    cout<<ksm(2,n-1);
    return 0;
}

题很简单,重要的是题带给我们的思考。考试时有一个知识点不知道,难度很容易就涨上去了。所以平时还是要多学,同时不能忘了学过的东西(公式书上可都有啊)。在做题时的审题也很重要,想想码上2小时后突然发现审错题时有多悲伤啊。。。

posted @ 2019-04-10 21:23  千叶繁华  阅读(164)  评论(0编辑  收藏  举报