出自某模拟赛。

题目大意:

对1e9+7取模。

数据范围
 20 % : n<=300
40 % : n<=2,000
50 % : n<=10,000
70 % : n<=1,000,000
100 % : n<=1,000,000,000

题解

方法众多。

然而我太蒟了,2h43min愣是写了一个40pts暴力走人。

开始指着想正解,但是发现想不出来,然后写n^2暴力,结果总是要么漏算要么算重要么取模出错。。。最后才调出来。

1.如果比较菜,请尝试打表:

$n^3$暴力显然。然后打表。

$n=1,ans_1=1$

$n=2,ans_2=6$

$n=3,ans_3=24$

$n=4,ans_4=80$

然后,套路的先观察相邻两项的关系。

然后尝试和项数的下标套上关系。

$ans_2=ans_1\times \frac{6}{1}$

$ans_3=ans_2\times \frac{8}{2}$

$ans_4=ans_3\times \frac{10}{3}$

诶,然后发现了规律!!

可以递推。

$f_{n+1}=f_n\times \frac{4+2\times n}{n}$

$f_{n+1}=f_n\times \frac{2\times(n+2)}{n}$

迭代下去得:

$f_{n+1}=f_1 \frac{2^n\times (n+2)!}{2n!}$

$f_{n+1}=\frac{2^{n}\times (n+1)\times(n+2)}{2}$

$f_{n}=\frac{2^{n-1}\times n\times(n+1)}{2}$

即可出结果

2.正解:

有点意思的是,i+n-i-1=n-1,k-j+j-1=k-1对于任意的i,j恒成立。

这就是突破口

考虑组合数的意义。

$\sum_{k=1}^n(k\times\sum_{j=1}^k\sum_{i=0}^{n-1}(C_i^{k-j}\times C_{n-i-1}^{j-1})$

$=\sum_{k=1}^n(k\times\sum_{i=0}^{n-1}\sum_{j=1}^k(C_i^{k-j}\times C_{n-i-1}^{j-1})$

j和i换了位置之后,

发现,其实i就是枚举的一个分割点,

然后对于选择的k-1个数,在1~i个数中选择k-j个,

在i+1~n-i-1个数中选择j-1个。

好像和$C_{n-1}^{k-1}$有些关系。

发现,对于$C_{n-1}^{k-1}$中的每个方案。

其实都可以找出0~n-1这n个分界点,然后统计一次。

每个方案被统计了n次。

所以,

原式

$=\sum_{k=1}^nk\times n\times C_{n-1}^{k-1}$

已经可以O(n)递推了。

我们可以用刚才的打表中方法,搞出递推式,然后迭代出来通项公式。

即可O(logn)求解。

3.但是这个还不够漂亮!!!

这个可是组合数啊!!不是一般的数。

组合数毕竟有实际的意义。

观察这个式子的组合意义。

$\sum_{k=1}^nk\times n\times C_{n-1}^{k-1}$

这个k-1和k,n有点麻烦。

提出来:

$=n\times (\sum_{k=1}^n(k-1)\times C_{n-1}^{k-1})+n\times 2^{n-1}$

第一个括号里面是什么意义?

对于n-1个数的集合中,所有子集的大小的和。

套路地,我们转化研究对象。

考虑每个元素被统计了几次。

就是:$2^{n-1-1}=2^{n-2}$

因为每个数自己必须出现一次,然后其他的数爱出现不出现。

所以,

$=n\times( n\times2^{n-2})+n\times 2^{n-1}$

然后就可以O(logn)计算了。

总结:

0.这个式子,我们尝试用数学知识、组合数公式化简,发现不容易化简。然后就要考虑组合数的意义。

1.组合数是一个有意义的数。这样的数学式子的推导,可以通过寻找式子的意义来进行化简。

往往起到立竿见影的效果。

2.打表找规律,要考虑把结果,递推关系和项的编号放在一起。

女神(goddess)——组合数学的更多相关文章

  1. JDK1.8新特性之Optional

    概念 Optional 是JDK1.8中出现的一个容器类,代表一个值存在或者不存在.原来使用null表示一个值不存在,现在Optional可以更好的表达这个概念.并且可以避免空指针异常. 场景分析 需 ...

  2. FJNU 1154 Fat Brother And His Love(胖哥与女神)

    FJNU 1154 Fat Brother And His Love(胖哥与女神) Time Limit: 2000MS   Memory Limit: 257792K [Description] [ ...

  3. [ACdream] 女神教你字符串——三个气球

    Problem Description 女神邀请众ACdream开联欢会,显然作为ACM的佼佼者,气球是不能少的~.女神准备了三种颜色的气球,红色,黄色,绿色(交通信号灯?) 有气球还不能满足女神,女 ...

  4. kali linux之窥看女神上网隐私(ettercap+wireshark+zenmap +dsniff)

    作者:小波 http://www.cnblogs.com/xiaobo-Linux/ 无聊就玩了玩,不要干一些坏事哟~~网上也有一些文章关于kali linux的,就实战了一番.kali是用的debi ...

  5. 海洋女神建新installshield交流群了,原来的老群都满了,请加新群哦,记得认真填写验证信息

    群号511751143 海洋女神installshield群

  6. 南邮CTF隐写之丘比龙的女神

    刚开始下载下图片来 习惯性的binwalk一下 没发现东西 formost一下也没分离出来 扔进c32asm中发现有nvshen.jpg 于是改后缀名字为.zip 解压nvshen.jpg发现无法解压 ...

  7. 找女神要QQ号码

    引言 我们组来了个美女程序员,我心里窃喜,哈哈这下机会来了.我在想怎么下手呢?好吧,还是从QQ号码开始,找到女神要到QQ号,哈哈,我真是个天才~~~ 是这样子滴 想法是美好的,现实是残酷的,找女神要Q ...

  8. poj 3734 Blocks 快速幂+费马小定理+组合数学

    题目链接 题意:有一排砖,可以染红蓝绿黄四种不同的颜色,要求红和绿两种颜色砖的个数都是偶数,问一共有多少种方案,结果对10007取余. 题解:刚看这道题第一感觉是组合数学,正向推了一会还没等推出来队友 ...

  9. 美女程序员是如何将QQ转换成题目中那串数字的--读博文《找女神要QQ号码》

    我只能说好好的端午节你们不约么?,还在这里写代码?我也是够无聊的,下班了不走也在这跟风写着玩!<找女生要QQ号码原文>原文链接http://www.cnblogs.com/iforever ...

随机推荐

  1. Codeforces Round #504 (rated, Div. 1 + Div. 2, based on VK Cup 2018 Final) E. Down or Right

    从(1,1,n,n)每次只变一个坐标,进行询问. 如果问到对角线有距离限制, 再从(1,1,n/2,n/2)询问到(n/2,n/2,n,n) 记住前半部分贪心忘上走,后本部分贪心往右走 因为最后的路线 ...

  2. TPO-18 C2 Possible participation in a sociology project

    TPO-18 C2 Possible participation in a sociology project 第 1 段 1.listen to a conversation between a s ...

  3. 算法工程师进化-NLP之主题模型

    1 引言 主题模型是文本挖掘的重要工具,近年来在学术界和工业届都获得了非常多的关注.学术界的工作主要集中在建模层面,即提出各种各样的主题模型来适应不同的场景,因此缺乏指导主题模型在工业场景落地的资源和 ...

  4. 各web服务器的特点和优势

    1.Tomcat 和 Jetty 面向java语言 天生就是重量级的web服务器.性能一般 2.IIS 只能在windows平台运行,windows作为服务器在稳定性与其他一些性能上不如类unix操作 ...

  5. html页面中完成查找功能

    最近在搞一个被很多人改了的框架,天天看代码看的头的晕了,不过感觉进步还挺大的,自己做了一个后台可配置前台查看两个库不同数据范围的东西,还挺满意,那天拿出来分享一下,今天先说一个这几天做的功能,就是ht ...

  6. Python基础灬函数(定义,参数)

    函数 函数定义 # 定义一个计算绝对值的函数 def cal_abs(x): if x >= 0: return x else: return -x # 调用函数 print('-1的绝对值是: ...

  7. PHP学习和使用总结

    起因 学习和使用PHP也有不少年头了,而自己也在学习和使用其他许多语言.我想通过这个总结来给自己一个交代.另一方面也分享一下开发经验,如何用PHP开发和管理大型的项目. 闲聊 许多人说自己1天学会PH ...

  8. asp.net 设计条码code 11的问题

    前一段时间思考了一些条码生成的问题,其实条码也可以说是加密的文件显示. 一个条码首先要有规定 比如code 11 又 1234567890 - 这11个字符组成 而1 又用 5码 表示 "1 ...

  9. linux-sftp-指定端口号登录远程主机

    sftp -oPort=60001 root@192.168.0.254 -o选项来指定端口号 -oPort=远程端口号

  10. Scrum立会报告+燃尽图(十月十日总第一次):选题

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2190 Scrum立会master:付佳 一.小组介绍 组长:付佳 组员: ...