연결된 목록은 노드의 모음인 매우 일반적인 데이터 구조입니다. 각 노드에는 데이터 항목과 다음 노드에 대한 포인터가 포함되어 있습니다. 연결 목록은 스택, 큐, 해시 테이블과 같은 데이터 구조를 구현하는 데 사용할 수 있으며 알고리즘 문제에서 자주 발생합니다.
많은 알고리즘 문제에서는 연결 목록을 반대로 바꿔야 합니다. 연결 리스트를 반전시키는 기본 아이디어는 연결 리스트의 각 노드를 이전 노드로 지정하고 마지막으로 첫 번째 노드를 연결 리스트의 꼬리 노드로 만드는 것입니다. 이 작업은 연결된 목록 검색, 병합, 정렬과 같은 다양한 시나리오에 적용될 수 있습니다.
이 기사에서는 PHP를 사용하여 연결 목록을 재귀적으로 역전하는 기능을 구현하는 방법을 소개합니다. 연결리스트, 재귀 등의 개념에 대해 잘 모르는 경우 먼저 관련 기본 지식을 스스로 배울 수 있습니다.
구현 방법
연결된 목록을 재귀적으로 역전하는 과정에서 연결 목록을 첫 번째 노드와 나머지 부분, 두 부분으로 나누어야 합니다. 나머지 부분을 반전시킨 후 반전된 목록의 끝에 첫 번째 노드를 삽입합니다. 이 프로세스는 재귀를 사용하여 구현할 수 있습니다. 구체적인 구현은 다음과 같습니다.
/** * 反转链表 * @param ListNode $head 头节点 * @return ListNode|null 反转后的头节点 */ function reverseList($head) { // base case if ($head == null || $head->next == null) { return $head; } // 反转剩余部分 $newHead = reverseList($head->next); // 将当前节点插入到反转后的链表末尾 $head->next->next = $head; $head->next = null; return $newHead; }
코드 분석
위 코드에서는 먼저 기본 사례를 처리합니다. 즉, 노드가 비어 있거나 다음 노드가 비어 있으면 노드 자체가 직접 반환됩니다. 그런 다음 나머지 노드를 재귀적으로 처리하여 역방향 연결 목록을 얻습니다.
다음으로 현재 노드를 역방향 목록의 끝에 삽입합니다. 구체적으로, 다음 노드 $head의 다음 노드를 현재 노드 $head 옆에 가리키고, $head의 다음 노드를 비우고, 마지막으로 반전된 헤드 노드 $newHead를 반환합니다.
또한 위 코드를 더 잘 이해하려면 연결 목록 노드의 정의도 추가해야 합니다.
class ListNode { public $val = 0; public $next = null; function __construct($val) { $this->val = $val; } }
테스트 사례
위 코드의 정확성을 확인하기 위해 다음과 같이 작성할 수 있습니다. 다음 테스트 케이스:
$head = new ListNode(1); $head->next = new ListNode(2); $head->next->next = new ListNode(3); $head->next->next->next = new ListNode(4); $head->next->next->next->next = new ListNode(5); $newHead = reverseList($head); print_r($newHead);
위의 테스트 케이스를 실행하면 다음과 같은 출력 결과를 얻을 수 있습니다.
ListNode Object ( [val] => 5 [next] => ListNode Object ( [val] => 4 [next] => ListNode Object ( [val] => 3 [next] => ListNode Object ( [val] => 2 [next] => ListNode Object ( [val] => 1 [next] => ) ) ) ) )
Conclusion
이 기사에서는 PHP 재귀를 사용하여 연결 목록의 반전 작업을 구현하는 방법을 소개합니다. 위의 데모를 통해 연결리스트 문제를 해결하는 데 있어 재귀 알고리즘의 우수성을 확인할 수 있습니다. 실제 개발에서는 실제 시나리오를 기반으로 문제를 해결하는 데 가장 적합한 알고리즘을 선택해야 합니다. 이 글이 독자들에게 도움이 되기를 바랍니다!
위 내용은 PHP 재귀를 사용하여 연결 목록을 뒤집는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

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

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

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