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 "<hr />"; 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 "<hr />"; print_r($head); } ?>
출력 결과:
역순 이전의 연결 목록:
노드 개체( [str] => [다음] => 노드 개체( [str] => 000000000000000 [다음] => 노드 개체( [str] => 111111111111 [다음] => ] => 2222222222222222 [다음] => 노드 개체( [str] => 333333333333 [다음] => 노드 개체( [str] => 444444444444 [다음] => 노드 개체( [str] = > 55555555555 [다음] => ; 노드 개체( [str] => 6666666666666 [다음] => 노드 개체( [str] => 7777777777777 [다음] => 노드 개체( [str] => 888888888888888 [다음] => 노드 객체 ( [str] => 9999999999999 [다음] => 노드 객체 ( [str] => 세계 [다음] => 노드 객체 ( [str] => 안녕하세요 [ 다음] => ) ) ) ) ) ) ) ) ) ) ) )
역순 후의 연결 목록:
Node Object ( [str] => [next] => Node Object ( [str] => Node Object ( [str] => 안녕하세요 [다음] => ) [다음] => 노드 개체 ( [str] => 노드 개체 ( [str] => 세계 [다음] => ) [ 다음] => 노드 객체( [str] => 노드 객체( [str] => 99999999999999 [다음] => ) [다음] => 노드 객체( [str] => 노드 객체( [ str] => 888888888888888) [다음] => ) [다음] => 노드 개체( [str] => 노드 개체( [str] => 7777777777777 [다음] => ) [다음] => ; 노드 개체( [str] ] => 노드 개체 ( [str] => 66666666666666 [다음] => ) [다음] => 노드 개체 ( [str] => 노드 개체 ( [str] => ; 55555555555 [다음] = > ) [다음] => 노드 개체( [str] => 노드 개체( [str] => 444444444444 [다음] => ) [다음] => 노드 개체( [str] => 노드 객체 ( [str] => 333333333333 [다음] => ) [다음] => 노드 객체 ( [str] => 노드 객체 ( [str] => 2222222222222222 [다음] ] => ) [ next] => 노드 객체( [str] => 노드 객체( [str] => 111111111111 [next] => ) [next] => 노드 객체( [str] = > 노드 객체( [ str] => 000000000000000 [next] => ) [next] ) ) ) ) ) ) ) )
관련 권장 사항:
위 내용은 PHP는 연결리스트의 역순을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.
