栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

大厂喜欢出的一道PHP面试题!

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

大厂喜欢出的一道PHP面试题!

算是一道常见的面试题引来的,有些大厂也喜欢把这个题当做面试题。

题目:例如有一个 1g 的文件,里面存放这乱序不唯一的数字,如果利用 100m 完成整体排序?

实现过程就是

1、先将大文件逐行读取,每 10000 行为一组,然后排序后写入文件中,文件名称类似 t1.txt, t2.txt ... 这样的名称,直至读取和拆分完毕整个文件,

2、然后遍历所有文件,每个文件先读取第一行,放入临时排序数组 $tmpNums**,然后取其中最小值,**放入临时存储数组 $nums,同时记录当前位置的索引值 $idx

3、从最小值所在索引对应文件中取下一个数字,放入临时排序数组的当前索引中,然后继续重复第 2 步的操作,直到所有文件的所有内容读取完毕,则整体文件重新排序完毕。

以下是一个 PHP 多路归并排序 demo 代码,只是简单的骨架结构,例如 min 取最小值部分,可以扩展成定长最小堆实现,或者优先队列,能保存值和所在文件就行

PHP 多路归并 demo 代码

function multiWaySort()
{
    // 读取所有的文件描述符

    $fds = [];
    $dir = scandir('./runtime/txt/');
    foreach ($dir as $file) {
 if ($file != '.' && $file != '..') {
     $fds[] = fopen('./runtime/txt/' . $file, 'rb');
 }
    }

    // 读取每个文件的第一行内容,放入临时排序数组

    $tmpNums = [];
    foreach ($fds as $fd) {
 $tmpNums[] = (int)fgets($fd);
    }

    $nums = [];
    $count = 0;
    while (true) {
 if (empty($tmpNums)) break;

 // 最小值放入临时存储数组

 $value = min($tmpNums);
 $nums[] = $value;  

 // 读取最小值所在索引,对应的文件下一行内容

 $idx = array_search($value, $tmpNums);
 $next = fgets($fds[$idx]);

 if (!$next) {
     unset($tmpNums[$idx]);
     unset($fds[$idx]);
 } else {
     $tmpNums[$idx] = (int)$next;
 }

 // 临时存储数组到达一定数量追加写入文件一次

 if (count($nums) == 20) {
     foreach ($nums as $value) {
  $f = fopen('./runtime/result.txt', 'ab+');
  fwrite($f, $value . PHP_EOL);
     }
     $nums = [];
 }

 if ($count == 4999999) {
     continue;
 }

 $count++;
    }
}

推荐学习:《PHP视频教程》

参考:

《详解K路归并排序(实战)》

《一文了解大文件排序/外存排序问题》

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/262347.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号