ACM~排列组合&&hdu样例

排列组合是数学中的一个分支,在计算机编程方面也有很多的应用,主要有排列公式和组合公式,错排公式、母函数、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的个数求出最小不连续的值

时间: 2024-10-09 05:32:34

ACM~排列组合&&hdu样例的相关文章

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

排列组合 HDU - 1521 一句话区分指数型母函数和母函数就是 母函数是组合数,指数型母函数是排列数 #include<bits/stdc++.h> using namespace std; #define maxn 12 double ans[maxn],tp[maxn],inv[maxn]; int n,m,a[maxn]; void init() { inv[0]=1; for(int i=1; i<=11; i++) inv[i]=inv[i-1]*i; } int main

noip 1995 灯的排列问题 排列组合 DFS

题目描述 设在一排上有N个格子(N≤20),若在格子中放置有不同颜色的灯,每种灯的个数记为N1,N2,……Nk(k表示不同颜色灯的个数). 放灯时要遵守下列规则: ①同一种颜色的灯不能分开: ②不同颜色的灯之间至少要有一个空位置. 例如:N=8(格子数) R=2(红灯数) B=3(蓝灯数) 放置的方法有: R-B顺序 R R B B B R R B B B R R B B B R R B B B R R B B B R R B B B B-R顺序 B B B R R B B B R R B B

HDU ACM 4465 Candy-&gt;概率-数学期望-排列组合

题意:有两个箱子,里面各放有糖n个,每天从两个之中任取一颗糖,突然有一天小孩取糖时发现一个盒子里空了,问另一个盒子里面现在有多少糖(求期望值)? #include<iostream> #include<cmath> using namespace std; double F[400008]; double C_N_M(int n,int m) { return F[n]-F[m]-F[n-m]; } void Init() { int i; F[0]=0; for(i=1;i<

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,求满足要求的(x, y, z)有多少组,并且要考虑顺序. 思路:如果L%G != 0显然不存在这样的(x, y, z),相反肯定存在.具体做法就是将L/G分解质因子,得到:L/G = P1^t1 * P2^t2 * ... * Pk^tk,我们来考虑任意一个因子Pi^ti,此时(x/G, y/G, z/

HDU 2068 RPG的错排(排列组合,错排)非常详细~

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2068 这道题需要用到错排公式以及高中数学排列组合的知识. 排列组合:[1]排列(从n中拿出m个,并进行排列):A_n_m=n!/(n-m)!=n*(n-1)*(n-2)*........(n-m+1); [2]组合(从n中拿出m个,不进行排列):C_n_m=n!/((n-m)!*m!)=n*(n-1)*(n-2)*........(n-m+1)/(m*(m-1)*.......1); 因此不难得出排

hdu 2200 Eddy&#39;s AC难题 (排列组合 就是求(a+b)的n次方的展开式)

Eddy's AC难题 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 3770    Accepted Submission(s): 1765 Problem Description Eddy是个ACMer,他不仅喜欢做ACM题,而且对于Ranklist中每个人的ac数量也有一定的研究,他在无聊时经常在纸上把Ranklist上每个人的

hdu 5366 排列组合

http://acm.hdu.edu.cn/showproblem.php?pid=5366 Problem Description ![](../../data/images/C613-1001-1.jpg) ZJiaQ want to become a strong man, so he decided to play the mook jong.ZJiaQ want to put some mook jongs in his backyard. His backyard consist o

hdu 1799 (循环多少次?)(排列组合公式)

循环多少次? Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 3051    Accepted Submission(s): 1117 Problem Description 我们知道,在编程中,我们时常需要考虑到时间复杂度,特别是对于循环的部分.例如, 如果代码中出现 for(i=1;i<=n;i++) OP ; 那么做了n次OP运算

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

1 // 排列组合+组合数取模 HDU 5894 2 // 题意:n个座位不同,m个人去坐(人是一样的),每个人之间至少相隔k个座位问方案数 3 // 思路: 4 // 定好m个人 相邻人之间k个座位 剩下就剩n-(m+1)*k个座位 5 // 剩下座位去插m个不同的盒子==就等价n个相同的球放m个不同的盒子 6 // 然后组合数出来了 7 // 乘n的话是枚举座位,除m是去掉枚举第一个座位的时候,剩下人相邻的座位相对不变的情况 8 9 #include <iostream> 10 #incl