linux编程的108种奇淫巧计-12(存储计算)续

     接上篇:linux编程的108种奇淫巧计-12(存储计算)

 

     关于购票问题其实是一个组合数学的问题,有通解可以直接求出。

     我们假定X轴为手持50元的人,Y轴为手持100元的人,那么一个正确的解等价于从(0,0)到(n,n)的格路问题,每次只能走一格,要么X加1,要么Y加1,如下所示的一条红线为一个8个人的解,即{50,50,100,100,50,50,100,100},先来2个50元的购票者,在来2个100元的购票者,与不例举。

      由格路问题的定义,从(0,0)到(n,n)的方案数如下图,但同时要扣除跨过y=x这条对角线的解方案,这等价于从(1,-1)到(n,n)的方案数。因此解得结果为两数之差,这个值就是Catalan数,因此没有必要向我们上面给出的方法,而是直接计算即可,在求解阶层的实际计算中为了防止大数溢出,可以遍历一遍找到乘积中2和5的个数,凑成1对,结果末尾就加个0,这样可以避免一定程度的溢出。

      当然本文主要是为了介绍存储计算的技巧,借用了这个例子,上文中我们用存储计算的方法把着每一个方案都枚举出来。存储计算就介绍到这里。

我要啦免费统计

本系列其他文章推荐:http://blog.csdn.net/pennyliang/category/746545.aspx

评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值