排列组合是数学中的一个分支。在计算机编程方面也有非常多的应用,主要有排列公式和组合公式。错排公式、母函数、Catalan Number(卡特兰数)等。

一、有关组合数学的公式

1、排列公式   P(n,r)=n!/r!

2、组合公式   C(n,r)=n!/(r!*(n-r)!)  C(n,r)=C(n-1,r)+C(n-1,r-1)

3、错排公式   d[1]=0;   d[2]=1;

d[n]=(n-1)*(d[n-1]+d[n-2])

4、卡特兰数

前几项:1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786,208012…

公式       C(n)=C(2n,n)/(n+1)

5、母函数

数学中,某个序列的母函数是一种形式幂级数,其每一项的系数能够提供关于这个序列的信息。使用母函数解决这个问题的方法称为母函数方法
母函数可分为非常多种,包含普通母函数指数母函数L级数贝尔级数狄利克雷级数。对每一个序列都能够写出以上每一个类型的一个母函数。构造母函数的目的通常是为了解决某个特定的问题,因此选用何种母函数视乎序列本身的特性和问题的类型。(百度百科)

母函数模板(针对n的分解):

/******************************
题目大意:求分解整数n的个数q(n)
例:
5 = 5;
5 = 4 + 1;
5 = 3 + 1 + 1;
5 = 3 + 2;
5 = 2 + 2 + 1;
5 = 2 + 1 + 1 + 1;
5 = 1 + 1 + 1 + 1 + 1;
sum(5) = 7;不区分顺序,
(3+2)与(2+3)为同一个
*******************************/
int main()
{
int
a[350],b[350],i,j,k,n;
while(
cin>>n&&n)
{
for(
i=0;i<=n;i++){
a[i]=1;
b[i]=0;
}
for(
i=2;i<=n;i++){
for(
j=0;j<=n;j++)
for(
k=0;k+j<=n;k+=i)
b[k+j]+=a[j];
for(
j=0;j<=n;j++){
a[j]=b[j];
b[j]=0;
}
}

cout<<a[n]<<endl;
}
return
0;
}

二、STL中的全排列函数

函数声明:#include  <algorithm>

bool next_permutation( iterator start, iterator end);

next_permutation()函数功能是输出全部比当前排列大的排列。顺序是从小到大。

prev_permutation()函数功能是输出全部比当前排列小的排列,顺序是从大到小。



三、自定义的全排列的函数

void range(int a[],int k,int n){

    if(k==n) {

        for(int i=1;i<=n;i++){

            printf("%d",a[i]);

        }

        printf("\n");

    }

    for(int i=k;i<=n;i++){

        swap(a[k],a[i]);

        range(a,k+1,n);

        swap(a[k],a[i]);

    }



}

四、hdu题目例子

题目一、hdu1027  给出n,m,求n个数的按字典序排列的第m个序列

题目二、hdu1028  求一个正整数n的分解个数

题目三、hdu1171  给出一些物品的价值和个数。分成两份,是这两份的价值相差最小

题目四、hdu1261  给定若干字母和它们对应的个数,计算能够组成多少个不同的字符(高精度)

题目五、hdu1398  给出一个数字n,用给定的序列,求出组成n的全部种类

题目六、hdu1465  错排公式的应用

题目七、hdu1492  求一个数的全部humber bunber的约数的个数

题目八、hdu1570  排列和组合公式的应用

题目九、hdu1716  有四张卡片,用这四张卡片能排列出非常多不同的4位数。从小到大的顺序输出这些4位数

题目十、hdu1799  用递推公式求组合的个数

题目十一、hdu1085 给出1、2、5的个数求出最小不连续的值

ACM~排列组合&amp;&amp;hdu例子的更多相关文章

  1. js 排列 组合 的一个简单例子

    最近工作项目需要用到js排列组合,于是就写了一个简单的demo. 前几天在网上找到一个写全排列A(n,n)的code感觉还可以,于是贴出来了, 排列的实现方式: 全排列主要用到的是递归和数组的插入 比 ...

  2. HDU 4497 GCD and LCM(分解质因子+排列组合)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4497 题意:已知GCD(x, y, z) = G,LCM(x, y, z) = L.告诉你G.L,求满 ...

  3. 4535 ACM 礼尚往来 数学排列组合

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=4535 题意:每个礼物都不相同的组合个数 数学规律: 将每个女友排序为1···n,对应的女友送男友的礼物排序 ...

  4. HDU 4045 Machine scheduling (组合数学-斯特林数,组合数学-排列组合)

    Machine scheduling Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  5. 排列组合+组合数取模 HDU 5894

    // 排列组合+组合数取模 HDU 5894 // 题意:n个座位不同,m个人去坐(人是一样的),每个人之间至少相隔k个座位问方案数 // 思路: // 定好m个人 相邻人之间k个座位 剩下就剩n-( ...

  6. 排列组合 HDU - 1521 -指数型母函数

    排列组合 HDU - 1521 一句话区分指数型母函数和母函数就是 母函数是组合数,指数型母函数是排列数 #include<bits/stdc++.h> using namespace s ...

  7. HDU 1521 排列组合 指数型母函数

    排列组合 Time Limit: 1000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & %I64u Submit Status D ...

  8. hdu 4451 Dressing 排列组合/水题

    Dressing Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  9. HDU 5816 状压DP&排列组合

    ---恢复内容开始--- Hearthstone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java ...

随机推荐

  1. Nginx配置文件nginx.conf具体解释

    #定义Nginx执行的用户和用户组user www www; #nginx进程数.建议设置为等于CPU总核心数. worker_processes 8; #全局错误日志定义类型,[ debug | i ...

  2. CRC校验的实现

    本例提供的是通过查表发来实现CRC校验. CRC余式表如下: unsigned int crctab[256] ={/*CRC余式表 */ 0x0000, 0x1021, 0x2042, 0x3063 ...

  3. JAVA 对象序列化(二)——Externalizable

    Java默认的序列化机制非常简单,而且序列化后的对象不需要再次调用构造器重新生成,但是在实际中,我们可以会希望对象的某一部分不需要被序列化,或者说一个对象被还原之后,其内部的某些子对象需要重新创建,从 ...

  4. Chilkat----开源站点之VS2010 CKMailMan一个很好的邮件发送开源开发包

    Chilkat 是一个很好的开源站点,有各种开源库. 开发语言主要有Classic ASP •C • C++ • C# • Delphi ActiveX • Delphi DLL • Visual F ...

  5. Revit手工创建族

    手工创建族 1.画两个参考平面. 图3001 2.点击族类型,添加参数. 图3002,3003 3.添加类型,为类型赋值. 3004 4.创建拉伸截面,完成后,可以三维查看. 3005 5.创建对齐, ...

  6. AngularJS的增删改查、state嵌套案例,不涉及服务端

    本篇实践一个案例,大致是:左边有导航菜单,右边显示列表,并可对列表项编辑或删除,也可添加新的列表项.借此,可体会到:如何组织可扩展的AngualrJS文件结构,如何点击左侧菜单项右侧显示相应内容,an ...

  7. 整理:iOS 短信与电话事件的获取

    整理:iOS 短信与电话事件的获取   background information: Core Telephony iOS 4.0 的官方 API 裡頭,多了一個叫做 Core Telephony  ...

  8. ArcGIS 在高清屏中主界面界面字体和图标显示过小,如何解决?

    作者:安日链接:https://www.zhihu.com/question/40658050/answer/132382971来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

  9. 禁止浏览器backspace键(退格键)时跳转页面(extjs,javascript)

    Ext实现方式: //方法一  var key = new Ext.KeyMap(document,{   key: 8,   fn: function(obj,e){    var type = e ...

  10. Android开发 AIDL使用自定义对象作参数或返回值

    http://www.pocketdigi.com/20121129/952.html 默认,AIDL支持对象作参数,但需要该对象实现Parcelable接口,且aidl文件应该是该类在同一包下,需要 ...