《编程珠玑》读书报告


最后几章还没怎么看,先写这么多吧。


第一部分:基础

第一章:开篇

        本章概括的讲述了如何用程序解决问题,包括:准确的问题描述、程序设计以及实现。

        本章首先提出了一个问题“如何给磁盘文件排序?”,并说明应该先对问题进行准确的描述,将已知条件组织成一种更客观、更易用的形式:输入、输出以及约束。在程序设计阶段,应该充分理解问题的特点,选择合适的解决方法。

第二章:啊哈!算法

        本章主要讲述了如何根据问题的特点,灵机一动,思考出合适的算法来解决特殊问题。

        本章提出了一个问题:

        给定一个最多包含40亿个随机排序的32位整数的顺序文件,找出一个不在文件中的32位整数。

        本章在此处提到了二分搜索,在程序设计中二分搜索是最常见的用于有序数据的搜索算法。对于上面的问题,可以找出其特殊性:232次方为4 294 967 296,也就是说,无论如何,都至少有一个整数不在顺序文件中。利用这一点,我们利用二分搜索的算法,不同之处在于,每次取中间数字,然后统计中间数字之上和之下的元素个数,若之上的元素个数大于之下的元素个数,则说明之下必然有一个缺失整数。

        上题的解决方法利用了题目的特殊性:题目仅仅要求找出一个不在文件中的整数,且整数范围大于整数个数,同时,结点二分搜索的原理(原理,必须于算法充分理解,理解其思路,活用算法)。

        本章提出的第二个问题:

        将一个n元一维向量向左旋转i个位置。例如,当n=8且i=3时,abcdefgh旋转为defghabc。

        该功能是微量的一个基本操作。旋转操作对应于交换相邻的不同大小的内存块:每当拖动文件中的一块文字到其它地方时,就要求程序交换两块内存中的内容,在许多场合下,运动时间和存储空间的约束会很严格。

        最基本的解决方法是:移动x[0]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值