接上篇: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

GitHub 加速计划 / li / linux-dash
13
2
下载
A beautiful web dashboard for Linux
最近提交(Master分支:4 个月前 )
186a802e added ecosystem file for PM2 5 年前
5def40a3 Add host customization support for the NodeJS version 5 年前
Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐