一.组合数:
问题引入:现在有 n 个球,取其中的 k 个球,问一共有多少
种方式?
答案:

公式直观解释:
我们考虑有顺序地取出 k 个球:第一次有 n 种选择,第二次有 n-1 种
选择,...,第 k 次有 n-k+1 种选择。故一共有
  
种方案数;但如果不计算顺序的话,那么对于一种方案,其实有 k! 种
不同的顺序,所以再除以 k! 即为最终的答案。
实际编程所需要的公式:C(n,k) = C(n − 1,k) + C(n − 1,k − 1)
题目:
luogu 2822 组合数问题(边计算边模)
luogu 1313 计算系数(答案为:a n × b m × C(k,n))

                          二.计数问题:
(1). 把 n 个数拆成 k 个非负整数,有多少种方案数?C(n,k)
(2). 把 n 个数拆成 k 个正整数,有多少种方案数?C(n,n-k+1)
1.放球问题:
1. 把 N 个不同的球放在 K 个不同箱子-----n^k
2. N 个相同的球放在 k 个不同的箱子-----C(n,n-k)
3. N 个不同的球放在 k 个相同的箱子
4. N 个相同的球放在 k 个相同的箱子
2.路径行走:
一个 N*M 的网格,每次只能向上或者向右,从左下角到右上角有
多少种方案数
C(n + m − 2,n − 1)

按照字典序的顺序从小写字母 a 开始按顺序给出序列 (序列中都为升序字符串,挑出长度位 L 的字符串有多少个?
                

练习:
(1)Codevs 1262 不要把球传我
(2)HDU 5698 瞬间移动
(3)HDU 1465
{
错排公式:设 F[i] 为每个数都不在自己的位置上的排列数。
* 则有公式 F[i] = (n-1) (F[i-1] + F[i-2])
假设在第 1 个位置上的是 k(k ̸= 1),则有两种情况:
1 在 k 的位置上的是 1。则这时候只需要要求其他的 n-2 个数不在
位置上即可。
2 在 k 的位置上不是 1。把 1 看作 k,相当于 n-1 个数都不在自己的
位置上。
}
(4)HDU 4704 Sum

{

  

}

数论基础之组合数&计数问题的更多相关文章

  1. 你也可以手绘二维码(二)纠错码字算法:数论基础及伽罗瓦域GF(2^8)

    摘要:本文讲解二维码纠错码字生成使用到的数学数论基础知识,伽罗瓦域(Galois Field)GF(2^8),这是手绘二维码填格子理论基础,不想深究可以直接跳过.同时数论基础也是 Hash 算法,RS ...

  2. 「kuangbin带你飞」专题十四 数论基础

    layout: post title: 「kuangbin带你飞」专题十四 数论基础 author: "luowentaoaa" catalog: true tags: mathj ...

  3. 数论篇7——组合数 & 卢卡斯定理(Lucas)

    组合数 组合数就是高中排列组合的知识,求解组合数C(n,m),即从n个相同物品中取出m个的方案数. 求解方式 求解通式:$C^{m}_{n}=\dfrac {n!}{m!\left( n-m\righ ...

  4. acm数论之旅--组合数(转载)

    随笔 - 20  文章 - 0  评论 - 73 ACM数论之旅8---组合数(组合大法好(,,• ₃ •,,) )  补充:全错排公式:https://blog.csdn.net/Carey_Lu/ ...

  5. lightoj1336数论基础

    #include<iostream> #include<cstdio> #include<cmath> #define ll long long using nam ...

  6. 数论基础算法总结(python版)

    /* Author: wsnpyo Update Date: 2014-11-16 Algorithm: 快速幂/Fermat, Solovay_Stassen, Miller-Rabin素性检验/E ...

  7. 从BZOJ2242看数论基础算法:快速幂,gcd,exgcd,BSGS

    LINK 其实就是三个板子 1.快速幂 快速幂,通过把指数转化成二进制位来优化幂运算,基础知识 2.gcd和exgcd gcd就是所谓的辗转相除法,在这里用取模的形式体现出来 \(gcd(a,b)\) ...

  8. 【数论】【组合数】【快速幂】【乘法逆元】洛谷 P2265 路边的水沟

    从左上角到右下角,共经过n+m个节点,从其中选择n各节点向右(或者m各节点向下),所以答案就是C(n+m,n)或者C(n+m,m),组合数暴力算即可,但是要取模,所以用了乘法逆元. #include& ...

  9. 1370 - Bi-shoe and Phi-shoe(LightOJ1370)(数论基础,欧拉函数)

    http://lightoj.com/volume_showproblem.php?problem=1370 欧拉函数: 在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目. φ(n) ...

随机推荐

  1. python __builtins__ frozenset类 (27)

    27.'frozenset', 返回一个冻结的集合,冻结后集合不能再添加或删除任何元素. class frozenset(object) | frozenset() -> empty froze ...

  2. 交表(Send a Table)

    #include<stdio.h> #include<string.h> #define N 50010 int phi[N],n,sum[N]; void phi_table ...

  3. 关于协程:nodejs和golang协程的不同

    nodejs和golang都是支持协程的,从表现上来看,nodejs对于协程的支持在于async/await,golang对协程的支持在于goroutine.关于协程的话题,简单来说,可以看作是非抢占 ...

  4. 进程与线程(2)- python实现多进程

    python 实现多进程 参考链接: https://morvanzhou.github.io/tutorials/python-basic/multiprocessing/ python中实现多进程 ...

  5. C++类 单冒号

    1.继承 class Base { }; class Derived : public Base { }; 示列: class Base   { public: int a=10;  }; class ...

  6. Java 学习列表

    这是从450家企业的招聘信息中统计而来,相对来说还是比较真实的,虽然有些公司的招聘要求万年不变,但还是可以大致反应企业的招聘要求的.

  7. Suricata产生的数据存储目录

    不多说,直接上干货! 我这里呢,分两种常用的Suricata. 一.源码编译安装的Suricata 这里不多说,大家可以去看我下面写的博客 使用 Suricata 进行入侵监控(一个简单小例子访问百度 ...

  8. 01_C++学习笔记_入门

    1.float类型只能表示数字里面的前6位或者前7位.也就是说c++只能保证float类型的数字的前6位是正确的.如果要求的精度更高的话,请使用double和long double. float精度是 ...

  9. linux给文件或目录添加apache权限

    系统环境:ubuntu11.10/apache2/php5.3.6 在LAMP环境中,测试一个简单的php文件上传功能时,发现/var/log/apache2/error.log中出现如下php警告: ...

  10. 在 Windows 7 中禁用IPv6协议/IPv6隧道

    How to disable certain Internet Protocol version 6 (IPv6) components in Windows Vista, Windows 7 and ...