不同种类不同个数集合的重复排列——指数型母函数

2024-03-27 22:58

本文主要是介绍不同种类不同个数集合的重复排列——指数型母函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们知道多元素的多重集排列是这样的:
元素   个数
a1       n1
a2       n2
a3       n3
……
ak       nk
其中n=n1+n2+……+nk
取出所有的元素,不同的排列情况应该是

当不是取出所有元素呢?
回想母函数的方法:
1g砝码,2g砝码,3g砝码……均有无限个,那么母函数的表达式就是
砝码故事的背景是所有的砝码都是”同类的“,而现在相当于是有不同种类的砝码,问排列情况。从这个角度看,指数型函数的答案应该比普通母函数的答案要大。
事实确实是这样:
最终得到:

答案就是 对应的

应用:
hdu 1521
http://acm.hdu.edu.cn/showproblem.php?pid=1521
大意:有n种物品,并且知道每种物品的数量。要求从中选出m件物品的排列数
#include <iostream>
#include <cstdio>
using namespace std;
int c[15],fac[15];
double c1[15],c2[15];
int main()
{fac[0]=1;for(int i=1;i<=10;i++) fac[i]=fac[i-1]*i;int n,m;while(cin>>n>>m){for(int i=1;i<=n;i++) scanf("%d",&c[i]);for(int i=0;i<15;i++) c1[i]=c2[i]=0.0;for(int i=0;i<=c[1];i++){c1[i]=1.0/fac[i];}for(int i=2;i<=n;i++){for(int j=0;j<=m&&j<=c[i];j++){for(int k=0;k+j<=m;k++){c2[k+j]=c2[k+j]+c1[k]/fac[j];}}for(int j=0;j<=m;j++){c1[j]=c2[j];c2[j]=0;}}printf("%.0lf\n",c1[m]*fac[m]);}return 0;
}


这篇关于不同种类不同个数集合的重复排列——指数型母函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/853678

相关文章

pandas使用apply函数给表格同时添加多列

《pandas使用apply函数给表格同时添加多列》本文介绍了利用Pandas的apply函数在DataFrame中同时添加多列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、Pandas使用apply函数给表格同时添加多列二、应用示例一、Pandas使用apply函

Python中Namespace()函数详解

《Python中Namespace()函数详解》Namespace是argparse模块提供的一个类,用于创建命名空间对象,它允许通过点操作符访问数据,比字典更易读,在深度学习项目中常用于加载配置、命... 目录1. 为什么使用 Namespace?2. Namespace 的本质是什么?3. Namesp

MySQL中如何求平均值常见实例(AVG函数详解)

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代... 目录前言一、基本语法二、示例讲解1. 计算全表平均分2. 计算某门课程的平均分(例如:Math)三、结合

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

python中的高阶函数示例详解

《python中的高阶函数示例详解》在Python中,高阶函数是指接受函数作为参数或返回函数作为结果的函数,下面:本文主要介绍python中高阶函数的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录1.定义2.map函数3.filter函数4.reduce函数5.sorted函数6.自定义高阶函数