PHP链表顺序反转,php 实现链表逆序

这篇文章介绍的内容是关于php 实现链表逆序 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下<?php

class Node {

public $str; public $next; function __construct ($str) {

$this->str = $str;

}

} //创建链表头

function createList () {

$head = new Node(null); return $head;

} //向链表$head中插入节点并赋值

function insertNode ($str, &$head) {

$node = new Node($str); $node->next = &$head->next; $head->next = &$node;

} //取出链表的第一个节点,相当于出队

function outQueue (&$head) {

$tmp = $head->next; $head->next = $head->next->next; $tmp->next = null; return $tmp;

} //将链表$head进行逆序

function reverse (&$head) {

$reversed = createList(null); while (null != $head->next) {

insertNode(outQueue($head), $reversed);

} return $reversed;

} $head = createList();

insertNode('hello', $head);

insertNode('world', $head);

insertNode('99999999999999', $head);

insertNode('888888888888888', $head);

insertNode('7777777777777', $head);

insertNode('66666666666666', $head);

insertNode('55555555555', $head);

insertNode('444444444444', $head);

insertNode('333333333333', $head);

insertNode('222222222222222', $head);

insertNode('111111111111', $head);

insertNode('000000000000000', $head);

print_r($head); $reversed = reverse($head); echo "


";

print_r($reversed); //上面的方法没有在原链表上操作,不过他创建了一个新链表,

//虽然逻辑实现显得简单,但是太不专业

//下面贴出更加专业的逆序代码

function reverse2 (&$head) {

$q = $head->next->next; $head->next->next = null; while (null != $q) { $p = $q; $q = $p->next; $p->next = $head->next; $head->next = $p;

}

reverse2($head); echo "


";

print_r($head);

} ?>

输出结果:

逆序前的链表:

Node Object ( [str] => [next] => Node Object ( [str] => 000000000000000 [next] => Node Object ( [str] => 111111111111 [next] => Node Object ( [str] => 222222222222222 [next] => Node Object ( [str] => 333333333333 [next] => Node Object ( [str] => 444444444444 [next] => Node Object ( [str] => 55555555555 [next] => Node Object ( [str] => 66666666666666 [next] => Node Object ( [str] => 7777777777777 [next] => Node Object ( [str] => 888888888888888 [next] => Node Object ( [str] => 99999999999999 [next] => Node Object ( [str] => world [next] => Node Object ( [str] => hello [next] => ) ) ) ) ) ) ) ) ) ) ) ) )

逆序后的链表:

Node Object ( [str] => [next] => Node Object ( [str] => Node Object ( [str] => hello [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => world [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 99999999999999 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 888888888888888 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 7777777777777 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 66666666666666 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 55555555555 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 444444444444 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 333333333333 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 222222222222222 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 111111111111 [next] => ) [next] => Node Object ( [str] => Node Object ( [str] => 000000000000000 [next] => ) [next] => ) ) ) ) ) ) ) ) ) ) ) ) )

相关推荐:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值