PHP实现耐心排序(patience sort)算法

藏色散人
发布: 2019-03-12 10:37:44
原创
3758人浏览过

耐心排序(patience sort)是一种排序算法,灵感来源于纸牌游戏patience,并以此命名。该算法的一个变体可以有效地计算给定数组中最长递增子序列的长度。

PHP实现耐心排序(patience sort)算法

该算法的名字来源于一个简化版的patience纸牌游戏。这个游戏以一副洗牌开始。按照下面的规则,这些卡片被一个接一个地摞在桌子上。

最初,没有"堆"。发出的第一张牌形成一张由单张牌组成的新牌。

随后的每一张牌被放置在现有"堆"的最左边,其顶牌的值大于或等于新牌的值,或位于所有现有"堆"的右边,从而形成新"堆"。

立即学习PHP免费学习笔记(深入)”;

当没有剩余的牌要发时,游戏就结束了。

算家云
算家云

高效、便捷的人工智能算力服务平台

算家云 37
查看详情 算家云

本文将此纸牌游戏转化为一种两阶段排序算法,如下所示。给定一个由n个元素组成的数组,这些元素来自一个完全有序的域,将这个数组看作是纸牌的集合,并模拟patience排序游戏。当游戏结束时,通过反复取出最小可见卡,恢复排序后的序列;换句话说,执行p堆的p-way合并,每个p堆都是内部排序的。

PHP实现耐心排序算法的代码实例如下:

<?php
class PilesHeap extends SplMinHeap {
    public function compare($pile1, $pile2) {
        return parent::compare($pile1->top(), $pile2->top());
    }
}
function patience_sort($n) {
    $piles = array();
    //排序成堆
    foreach ($n as $x) {
        //二进位检索
        $low = 0; $high = count($piles)-1;
        while ($low <= $high) {
            $mid = (int)(($low + $high) / 2);
            if ($piles[$mid]->top() >= $x)
                $high = $mid - 1;
            else
                $low = $mid + 1;
        }
        $i = $low;
        if ($i == count($piles))
            $piles[] = new SplStack();
        $piles[$i]->push($x);
    }
    // 优先队列允许我们有效地合并堆
    $heap = new PilesHeap();
    foreach ($piles as $pile)
        $heap->insert($pile);
    for ($c = 0; $c < count($n); $c++) {
        $smallPile = $heap->extract();
        $n[$c] = $smallPile->pop();
        if (!$smallPile->isEmpty())
            $heap->insert($smallPile);
    }
    assert($heap->isEmpty());
}
$a = array(100, 54, 7, 2, 5, 4, 1);
patience_sort($a);
print_r($a);
登录后复制

输出:

Array 
( 
[0] => 100 
[1] => 54 
[2] => 7 
[3] => 2 
[4] => 5 
[5] => 4 
[6] => 1 
)
登录后复制

本篇文章就是关于耐心排序(patience sort)算法的介绍,简单易懂,希望对需要的朋友有所帮助!

以上就是PHP实现耐心排序(patience sort)算法的详细内容,更多请关注php中文网其它相关文章!

相关标签:
php
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号