组合数板子

1. 预处理:

#include<cstdio>
const int N = 2000 + 5;
const int MOD = (int)1e9 + 7;
int comb[N][N];//comb[n][m]就是C(n,m)
void init(){
    for(int i = 0; i < N; i ++){
        comb[i][0] = comb[i][i] = 1;
        for(int j = 1; j < i; j ++){
            comb[i][j] = comb[i-1][j] + comb[i-1][j-1];
            comb[i][j] %= MOD;
        }
    }
}
int main(){
    init();
}

2. 当c[MAX][MAX]开不下的时候用,也是预处理:

#include<cstdio>
const int N = 200000 + 5;
const int MOD = (int)1e9 + 7;
int F[N], Finv[N], inv[N];//F是阶乘,Finv是逆元的阶乘 
void init(){
    inv[1] = 1;
    for(int i = 2; i < N; i ++){
        inv[i] = (MOD - MOD / i) * 1ll * inv[MOD % i] % MOD;
    }
    F[0] = Finv[0] = 1;
    for(int i = 1; i < N; i ++){
        F[i] = F[i-1] * 1ll * i % MOD;
        Finv[i] = Finv[i-1] * 1ll * inv[i] % MOD;
    }
}
int comb(int n, int m){//comb(n, m)就是C(n, m) 
    if(m < 0 || m > n) return 0;
    return F[n] * 1ll * Finv[n - m] % MOD * Finv[m] % MOD;
}
int main(){
    init();
}

3. 采用分解质因子的方式,可以计算足够大的数(因为数字会超过long long的范围,所以结果依然用质因子表示,模板中计算出了相应的数)(#include <map>)

map <int, LL> m;

//分解质因数
//k为1或-1
void fun(int n, int k)
{
    for (int i = 2; i <= sqrt(n * 1.0); i++)
    {
        while (n % i == 0)
        {
            n /= i;
            m[i] += k;
        }
    }
    if (n > 1)
    {
        m[n] += k;
    }
}

//大数快速幂取模
LL quick_pow(LL a, LL b)
{
    LL ret = 1;
    while (b)
    {
        if (b & 1)
        {
            ret *= a;
            ret %= MOD;
        }
        b >>= 1;
        a *= a;
        a %= MOD;
    }
    return ret;
}

//求组合数
LL C(LL a, LL b)
{
    if (a < b || a < 0 || b < 0)
        return 0;
    m.clear();
    LL ret = 1;
    b = min(a - b, b);
    for (int i = 0; i < b; i++)
    {
        fun(a - i, 1);
    }
    for (int i = b; i >= 1; i--)
    {
        fun(i, -1);
    }

    ///以下计算出了具体的数
    for (__typeof(m.begin()) it = m.begin(); it != m.end(); it++)
    {
        if ((*it).second != 0)
        {
            ret *= quick_pow((*it).first, (*it).second);
            ret %= MOD;
        }
    }
    return ret;
}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值