鱼C论坛

 找回密码
 立即注册
查看: 2075|回复: 12

各位大佬帮忙看看这道题用c语言或c++怎么写?

[复制链接]
发表于 2022-6-4 15:36:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
选修程序设计和算法课程的学生人数为 n,任课老师设置了 m 道练习题目 (其中:1 <= m,n <= 100),假定每道题的难度和知识点都是一样的,要求选修本课程的同学利用在线测评系统完成一道题目,同时还要求每道题目至少要被做过一次,问有多少种做题方案?当然也有可能没有一种方案存在。

输入描述
多组输入,每一行输入两个用一个空格分开的整数 n 和 m

输出描述
占一行,对应输入的每组数,输出对应的方案数

样例输入:
4 2

15 12

样例输出:
7

106470
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-6-4 17:38:50 | 显示全部楼层
数学上的写法是(C1n+C2n+c3n+......cnn)** m,你看看怎么编程 【C后面是上标和下标】,你看看对不
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 08:45:08 From FishC Mobile | 显示全部楼层
心之月语 发表于 2022-6-4 17:38
数学上的写法是(C1n+C2n+c3n+......cnn)** m,你看看怎么编程 【C后面是上标和下标】,你看看对不

4和2用你的公式  咋能弄出7来
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 10:12:18 | 显示全部楼层
wp231957 发表于 2022-6-5 08:45
4和2用你的公式  咋能弄出7来

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 10:14:56 | 显示全部楼层
其实我知道这题题解就是  第二类斯特林数,但是对于数学公式我不完全了解,所以不会写,哈哈哈哈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 12:07:09 From FishC Mobile | 显示全部楼层
傻眼貓咪 发表于 2022-6-5 10:14
其实我知道这题题解就是  第二类斯特林数,但是对于数学公式我不完全了解,所以不会写,哈哈哈哈

闲着无聊,把15,12的106470给手工算出来了
2022-06-05_12-06-23.jpg

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
人造人 + 5 + 5 + 3 鱼C有你更精彩^_^

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 2 反对 0

使用道具 举报

发表于 2022-6-5 12:49:16 | 显示全部楼层
wp231957 发表于 2022-6-5 12:07
闲着无聊,把15,12的106470给手工算出来了

厉害
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 12:52:55 | 显示全部楼层
wp231957 发表于 2022-6-5 12:07
闲着无聊,把15,12的106470给手工算出来了

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 12:55:39 From FishC Mobile | 显示全部楼层
傻眼貓咪 发表于 2022-6-5 12:49
厉害

可惜,无法描述成语言算法
二叉树???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 13:23:20 | 显示全部楼层
我还真的写出来了,哈哈哈
#include <iostream>
#include <cmath>

namespace StirlingNumber {

    // 階乘
    unsigned long long f(int n) {
        if (not n) return 1;
        return n * f(n - 1);
    }

    // 组合公式
    unsigned long long C(int n, int k) {
        return (f(n)) / (f(k) * f(n - k));
    }

    // 第二类斯特林数
    unsigned long long S(int n, int m) {
        if (not n) return 1;
        else if (not m) return static_cast<unsigned long long> (pow(m, n));
        else if (m == 1 or n == m) return m;
        else if (m == 2) return static_cast<unsigned long long> (pow(2, n - 1)) - 1;
        else if (m == n - 1)return C(n, 2);
        else if (m == n - 2) return C(n, 3) + 3 * C(n, 4);
        else if (m == 3) return static_cast<unsigned long long> (.5 * pow(3, n - 1) - pow(2, n - 1));
        else if (m == n - 3) return C(n, 4) + 10 * C(n, 5) + 15 * C(n, 6);
        return S(n - 1, m - 1) + m * S(n - 1, m);
    }
}

using namespace StirlingNumber;
using std::cout, std::endl;
int main(void) {
    cout << S(15, 12) << endl;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 13:25:51 | 显示全部楼层
wp231957 发表于 2022-6-5 12:55
可惜,无法描述成语言算法
二叉树???

不用二叉数,运用第二类斯特林数的所有特征条件,用递归写出来了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 13:53:24 From FishC Mobile | 显示全部楼层
傻眼貓咪 发表于 2022-6-5 13:25
不用二叉数,运用第二类斯特林数的所有特征条件,用递归写出来了。

这玩意没有通项公式啊!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-6-5 15:16:24 | 显示全部楼层
wp231957 发表于 2022-6-5 13:53
这玩意没有通项公式啊!!!

是啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-6 02:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表