组合数板子(四种)

模板一

范围较小时递推板子:(a,b<2000)支持多组询问 时间复杂度o(N^2)

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int mod=1e9+7;
const int N=2010;
int c[N][N];
void init()
{
    for(int i=0;i<N;i++)
    {
        for(int j=0;j<=i;j++)
        {
            if(!j)
                c[i][j]=1;
            else
            {
                c[i][j]=(c[i-1][j]+c[i-1][j-1])%mod;
            }
        }
    }
}
int main()
{
    init();
    int n;
    cin>>n;
    while(n--)
    {
        int a,b;
        cin>>a>>b;
        cout<<c[a][b]<<endl;
    }
    return 0;
}

模板二

范围(a<=1e6):支持多组询问时间复杂度o(N*logN)

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int mod=1e9+7;
const int N=1e5+10;
ll f[N],invf[N];
ll pows(ll a,ll n)
{
    ll ans=1;
    while(n)
    {
        if(n&1)
        {
            ans=ans*a%mod;
        }
        a=a*a%mod;
        n>>=1;
    }
    return ans;
}
void init()
{
    f[1]=1;
    invf[1]=pows(f[1],mod-2);
    for(int i=2; i<N; i++)
    {
        f[i]=f[i-1]*i%mod;
        invf[i]=pows(f[i],mod-2);
    }
}
ll c(ll a,ll b)
{
    return f[a]*invf[a-b]%mod*invf[b]%mod;
}
int main()
{
    init();
    int n;
    cin>>n;
    while(n--)
    {
        ll a,b;
        cin>>a>>b;
        if(a==b)
        {
            cout<<1<<endl;
        }
        else
            cout<<c(a,b)<<endl;
    }
    return 0;
}

模板三

范围 a<1e18 p<1e5;
卢卡斯定理:
C{a,b}同余C{a%p,b%p}*C{a/p,b/p};在modP意义下

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int mod=1e9+7;
const int N=1e5+10;
ll p;
ll pows(ll a,ll n)
{
    ll ans=1;
    while(n)
    {
        if (n & 1)
        {
            ans=ans*a%p;
        }
        a=a*a%p;
        n>>=1;
    }
    return ans;
}
ll C(ll a,ll b)
{
    if (b > a)
        return 0;
    ll res=1;
    for(ll i=1,j=a; i<=b; i++,j--)
    {
        res=res*j%p;
        res=res*pows(i,p-2)%p;
    }
    return res;
}
ll lucas(ll a,ll b)
{
    if(a<p&&b<p)
        return C(a,b);
    return (C(a%p,b%p)*lucas(a/p,b/p))%p;
}
int main()
{
    int n;
    cin>>n;
    while(n--)
    {
        ll a,b;
        cin>>a>>b>>p;
        cout<<lucas(a,b)<<endl;
    }
    return 0;
}

模板四

求:C{A,B} 不mod 需要高精度

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int mod=1e9+7;
const int N=1e5+10;
int prim[N],cnt;
int st[N];
int sum[N];
void prime()//欧拉筛素数
{
    for(int i=2;i<N;i++)
    {
        if(!st[i])
            prim[cnt++]=i;
        for(int j=0;prim[j]<=N/i;j++)
        {
            st[prim[j]*i]=1;
            if(i%prim[j]==0)
                break;
        }
    }
}
int get(int x,int p)//求素数出现的次数
{
    int res=0;
    while(x)
    {
        res+=x/p;
        x=x/p;
    }
    return res;
}
vector<int> mul(vector<int> a,int p)
{
    vector<int >g;
    int t=0;
    for(int i=0;i<a.size();i++)
    {
        t+=a[i]*p;
        g.push_back(t%10);
        t/=10;
    }
    while(t)
    {
        g.push_back(t%10);
        t/=10;
    }
    return g;

}
int main()
{
    int a,b;
    cin>>a>>b;
    prime();
    for(int i=0;i<cnt;i++)
    {
        int p=prim[i];
        sum[i]=get(a,p)-get(b,p)-get(a-b,p);
    }
    vector<int> res;
    res.push_back(1);
    for(int i=0;i<cnt;i++)
    {
        for(int j=0;j<sum[i];j++)
        {
            res=mul(res,prim[i]);
        }
    }
    for(int i=res.size()-1;i>=0;i--)
    {
        cout<<res[i];
    }
    cout<<endl;
    return 0;
}

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Arduino数字时钟的代码通常涉及硬件电路连接和软件编程两部分。以下是一个简单的步骤和代码示例,使用Arduino Uno或类似板子: **硬件连接:** 1. 连接一个数码管(7段显示)到Arduino的数字引脚,如D4至D7。 2. 如果需要,使用电阻分压器连接5V电源,以便控制数码管的亮度。 3. 连接电源和地线。 **软件编程(使用Arduino IDE):** ```cpp // 定义数码管的引脚 #define SEGMENT_A 4 #define SEGMENT_B 5 #define SEGMENT_C 6 #define SEGMENT_D 7 #define SEGMENT_E 8 #define SEGMENT_F 9 #define SEGMENT_G 10 #define COLON 11 // Arduino库中的Time类 #include <Time.h> Time time; void setup() { // 初始化数码管和时钟引脚为输出 pinMode(SEGMENT_A, OUTPUT); pinMode(SEGMENT_B, OUTPUT); // ...(其他数码管引脚设置) pinMode(COLON, OUTPUT); // 初始化Time类 time.begin(); } void loop() { // 获取当前时间并分割成小时、分钟和秒 int hours = time.getHours(); int minutes = time.getMinutes(); int seconds = time.getSeconds(); // 格式化显示时间 displayTime(hours, minutes, seconds); delay(1000); // 每秒更新一次 } void displayTime(int hours, int minutes, int seconds) { // 清除数码管 digitalWrite(SEGMENT_A, LOW); digitalWrite(SEGMENT_B, LOW); // ...(其他数码管) // 组合小时、分钟和秒,显示到对应数码管上 // 示例:显示“03:45:12” if (hours < 10) { digitalWrite(SEGMENT_A, HIGH); } else { digitalWrite(SEGMENT_G, HIGH); } // ...(处理分钟和秒) // 如果需要显示冒号,例如“03:45:12” if (seconds == 0) { digitalWrite(COLON, LOW); } else { digitalWrite(COLON, HIGH); } } ``` **相关问题--:** 1. 这段代码使用了哪个Arduino库来处理时间? 2. 为什么要用`Time`类? 3. 如何根据时间变化调整数码管显示的内容?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值