博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
编程之美 第1章 游戏之乐——游戏中碰到的题目(二)
阅读量:6903 次
发布时间:2019-06-27

本文共 1327 字,大约阅读时间需要 4 分钟。

1.3 一摞烙饼的排序

题意:一摞大小不一的烙饼,一次抓住最上面的几块饼,上下颠倒,反复几次,实现大的在下面,小的在上面。

解法一是一种非常清晰明了的解法,把最大的饼翻到最上面,再翻转整摞烙饼,把次大的翻到最上面,再把次大的翻转到最大的上面……如此反复2(n-1)次,整个都是有序的了。

文章后面讨论是如何找出最优的翻转方案,而不是给出一个翻转算法,暂不讨论。

对于翻转算法来说,解法一的复杂度已经比较小了,而且清晰明了。因此,笔者并没有太多的想优化这个算法的想法。

这个算法让笔者想起了著名的KISS原则——“Keep It Simple, Stupid!”

1.4 买书问题

这道题目动态规划解法是一个很好的选择,书上也给出了非常详细的解释,这里不多说了,直接给出Python代码。

def input_data():    book = raw_input().split(" ")    return [ int(i) for i in book ]f = {}def F(*arguments, **keywords):    if keywords.get("book") == None:        x = list(arguments)    else:        x = keywords["book"]    x.sort(reverse=True)    x = tuple(x)        if x in f:        return f[x]        s = []    if(x[4] > 0):        s.append(5 * 8 * 0.75 + F(x[0] - 1, x[1] - 1, x[2] - 1, x[3] - 1, x[4] - 1))    if(x[3] > 0):        s.append(4 * 8 * 0.8 + F(x[0] - 1, x[1] - 1, x[2] - 1, x[3] - 1, x[4]))    if(x[2] > 0):        s.append(3 * 8 * 0.9 + F(x[0] - 1, x[1] - 1, x[2] - 1, x[3], x[4]))    if(x[1] > 0):        s.append(2 * 8 * 0.95 + F(x[0] - 1, x[1] - 1, x[2], x[3], x[4]))    if(x[0] > 0):        s.append(8 + F(x[0] - 1, x[1], x[2], x[3], x[4]))            money = min(s) if len(s) else 0    f[x] = money    return moneydef main():    print F(book=input_data())if __name__ == "__main__":    main()

转载于:https://www.cnblogs.com/xcoder/archive/2012/10/15/2724344.html

你可能感兴趣的文章
redis python监控
查看>>
php趣味 - php 奥运五环
查看>>
Ext4 Disk Layout-2
查看>>
原 2017/5 JavaScript基础6--- 对象
查看>>
Python 列表、元组、字典t的常用方法
查看>>
MYSQL groupby使用方法。
查看>>
如何将ppt转换成pdf
查看>>
PowerDesigner连接MySQL数据库
查看>>
文件格式转换控件LEADTOOLS ePrint Professional
查看>>
ORACLE常见的六种RMAN恢复测试
查看>>
(Portal 开发读书笔记) Personalization
查看>>
SRCNN 实验细节
查看>>
Java多线程第二节-线程的基本使用
查看>>
界面控件Essential Studio for ASP.NET Web Forms 2017 v3发布丨附下载
查看>>
教你制作属于自己的CentOS 6.4一键自动化安装ISO镜像光盘
查看>>
线上 mysql 主库配置文档
查看>>
Java web部署目录结构和web.xml作用
查看>>
负载均衡DR(direct routing)模式
查看>>
Python中list的遍历
查看>>
Linux下查看内存等硬件信息
查看>>