51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 9977|回复: 29
打印 上一主题 下一主题

[讨论] 淘宝的一道面试题

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2010-5-4 11:35:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
淘宝的一道面试题

在一个100G的文件里有一堆数字,试找出100个最大的数字?!

【只要求写出,解题的思想及其所用到的知识,因为完整的解题过程太长】
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2010-5-4 13:09:27 | 只看该作者
问题难点为文件大小达100G,假如文件大小为1k,这个问题很好解决。
所以,把文件进行分割,每块中取最大的100个数字,再把各块的100个数字进行比较。
则所需时间可限制在可接受范围内。
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2010-5-4 14:59:24 | 只看该作者

回复 1# 的帖子

一点想法:仅供参考,不知对否。
建一个100的最小堆来存储最大的100个数,遍历整个文件并不断更新堆可得结果,需要进行优化以满足时间要求,比如遍历方式等,将文件分块之类的……
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2010-5-4 16:21:28 | 只看该作者
不错,顶。这道题有点意思。
回复 支持 反对

使用道具 举报

  • TA的每日心情
    擦汗
    2015-9-7 11:00
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    5#
    发表于 2010-5-4 18:07:21 | 只看该作者
    这是测试的面试题??
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    6#
    发表于 2010-5-4 22:38:08 | 只看该作者
    多线程+队列
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    7#
    发表于 2010-5-5 08:04:39 | 只看该作者
    100G文件里有一堆数字?请问是100G中全部为数字吗?还是100G里有的是数字,还有不是数字的?
    如果全为数字,写个C的程序,冒泡排列就可以
    如果不是全为数字,先要找出是数字的,再排列!
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2017-9-20 12:50
  • 签到天数: 2 天

    连续签到: 1 天

    [LV.1]测试小兵

    8#
    发表于 2010-5-5 08:55:09 | 只看该作者
    我也想到了冒炮排序法
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    9#
    发表于 2010-5-5 09:06:21 | 只看该作者
    ::ysssn::: 算法快忘没了,得补补了
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    10#
    发表于 2010-5-5 09:41:36 | 只看该作者
    借力实现
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    11#
    发表于 2010-5-5 10:28:54 | 只看该作者
    冒泡的话 估计100G 的数据 估计计算量太大了 无法实现吧  就算CPU 受的了 要跑多长时间啊
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    12#
     楼主| 发表于 2010-5-6 11:57:11 | 只看该作者

    回复 7# 的帖子

    问题是100G啊, 100G里全部是数字
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    13#
     楼主| 发表于 2010-5-6 11:59:41 | 只看该作者
    2# 回答的很好, 我当时也这么想的, 我是按1024字节, 1024字节 分割的
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    14#
    发表于 2010-5-6 12:12:52 | 只看该作者
    弱弱地问下,文件有索引吗?
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    15#
    发表于 2010-5-6 12:57:55 | 只看该作者
    ::JFBQ00125080410a:::
    分块取前100个,块内再按算法由大到小取前100个
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    奋斗
    2022-5-8 19:23
  • 签到天数: 137 天

    连续签到: 1 天

    [LV.7]测试师长

    16#
    发表于 2010-5-6 13:37:46 | 只看该作者
    这道题类似之前在论坛看到的,在100G的文件中,查找中值
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    17#
    发表于 2010-6-2 08:20:38 | 只看该作者
    1.算法的话,先找出所有的数字,然后大顶堆排序
    2.最简单的是导入数据库,直接一个select,然后按大小排序
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    18#
    发表于 2011-1-8 19:02:21 | 只看该作者
    集思广益
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    19#
    发表于 2011-1-11 20:09:22 | 只看该作者
    嗯……没思路……

    最大的只有一个吧,100个还能称“最”
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    20#
    发表于 2011-1-12 11:32:50 | 只看该作者
    这算什么测试?
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-12 03:42 , Processed in 0.080466 second(s), 27 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表