slgqhcsdn 2022-02-05 19:30 采纳率: 76.9%
浏览 29
已结题

一道斯特林数题,c++代码

题目描述
给定n 个有标号的球,标号依次为1,2,…,n。将这n个球放入r 个相同的盒子里,不允许有空盒,问有多少种放置方法。
例如把4个球放入2个盒子有7种方法,这7 种不同的放置方法依次为:
{(1),(234)}, {(2),(134)},
{(3),(124)}, {(4),(123)},
{(12),(34)}, {(13),(24)},{(14),(23)}。

输入格式
第一行输入两个整数n,r(1<=r<=n<=20)。

输出格式
输出一个整数表示方案总数。

输入样例
4 2

输出样例
7

  • 写回答

1条回答 默认 最新

  • iMingzhen 2022-02-05 21:29
    关注

    使用第二类斯特林数解

    #include<cstdio>
    long long a[25][25]; //a数组是用来递推的数组,注意本题需要使用longlong类型
    int main()
    {
        int r,n;
        scanf("%d %d",&n,&r); //输入球数以及盒子数
        for(int i=1;i<=n;i++) //外层循环枚举球数
        {
            for(int j=1;j<=r;j++) //内层循环枚举盒子数
            {
                if(i<j||j==0) break; 
                //如果盒子数大于球数,或者球数为0,就没有方法
                else if(i==1||j==1) a[i][j]=1; 
                //如果盒子数等于1或者球数等于1,就只有一种方法
                     else a[i][j]=a[i-1][j-1]+j*a[i-1][j]; 
                     //常规情况
            }
        }
        printf("%lld\n",a[n][r]); //输出解
        return 0;  //结束
    }  
    
    

    参考
    https://blog.csdn.net/qq_42995099/article/details/82193829

    补个扩展,LeetCode的第一类斯特林数题目
    https://leetcode-cn.com/problems/determine-whether-matrix-can-be-obtained-by-rotation

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 2月13日
  • 已采纳回答 2月5日
  • 创建了问题 2月5日

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算