免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2086 | 回复: 2
打印 上一主题 下一主题

编程珠玑 第二版 第一章例子的思考 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-12-20 17:23 |只看该作者 |倒序浏览
问题:
输入,输入为一个文件,至多包含n个正整数,每个正整数都小于n,这里n=10 的7次方(最多用40MB主存空间)。
如果输入时某个整数出现了两次,就会产生致命错误。
输出:以增序输出经过排序的整数列表。
约束:只有1MB的可用主存(代码除外);但磁盘空间非常充足。

解决方法:分40次读入输入文件,第一次读入0-249999之间的数(最多占1MB),排序后输出到文件中,
第二次读入250000-499999之间的数,排序后输出到文件,第40次读入排序9750000-9999999之间的整数
并输出到文件,至此所有数据都已经排好序。这个方法确实很巧妙,但我想说的是排序方法,书中指出
用快速排序很快,但我想在没有多余空间的情况下是否能用快速排序呢?并且在目前这种情况下,快速排序
未必是最快的方法。基于排序对象是整数而且无重复数据的这一事实,我们可以设一个250000个元素的整数数组,第一次
输入(0-249999)可以各就各位,即0存入元素0,249999存入元素249999,一遍即可排好序,而且也无须
额外的存储空间,第二次(250000-499999)把每个待排序的数减去250000,一样可以与数组一一对应,第三次则减去500000,
以后以此类推。

[ 本帖最后由 weiqiboy 于 2007-12-20 17:25 编辑 ]

论坛徽章:
26
处女座
日期:2016-04-18 14:00:4515-16赛季CBA联赛之深圳
日期:2020-06-02 10:10:5015-16赛季CBA联赛之广夏
日期:2019-07-23 16:59:452016科比退役纪念章
日期:2019-06-26 16:59:1315-16赛季CBA联赛之天津
日期:2019-05-28 14:25:1915-16赛季CBA联赛之青岛
日期:2019-05-16 10:14:082016科比退役纪念章
日期:2019-01-11 14:44:062016科比退役纪念章
日期:2018-07-18 16:17:4015-16赛季CBA联赛之上海
日期:2017-08-22 18:18:5515-16赛季CBA联赛之江苏
日期:2017-08-04 17:00:4715-16赛季CBA联赛之佛山
日期:2017-02-20 18:21:1315-16赛季CBA联赛之天津
日期:2016-12-12 10:44:23
2 [报告]
发表于 2007-12-20 18:34 |只看该作者

论坛徽章:
0
3 [报告]
发表于 2007-12-20 21:50 |只看该作者
看过。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP