C++에서 연결 리스트의 재귀 삽입 및 순회
연결된 목록을 구성하는 데 사용되는 정수 값을 얻습니다. 작업은 먼저 재귀적 방법을 사용하여 단일 연결 목록을 삽입한 다음 순회하는 것입니다.
끝에 노드를 재귀적으로 추가
헤드가 NULL인 경우 → 헤드에 노드 추가
그렇지 않으면 헤드에 추가( head → next)
노드를 통해 재귀적으로 반복
헤드가 NULL인 경우 → 종료
-
그렇지 않으면 인쇄( head → next )
Example
Input− 1 - 2 - 7 - 9 - 10
Output
Output Strong>− 연결 목록 : 1 → 2 → 7 → 9 → 10 → NULL
Input− 12 - 21 - 17 - 94 - 18
Output− 연결 목록: 12 → 21 → 17 → 94 → 18 → NULL
사용 방법 다음 프로그램에서는 다음과 같습니다
이 방법에서는 함수를 사용하여 노드를 추가하고 단일 연결 목록을 순회하며 다음 입력을 위해 재귀적으로 호출합니다.
정수와 다음 포인터가 포함된 구조체 SLLNode*를 가져옵니다.
-
Function addtoEnd(SLLNode* head, int data) 연결된 목록의 헤드에 대한 포인터와 데이터 부분의 정수를 가져오고 연결 목록의 끝에 노드를 추가합니다.
li> 헤드 포인터가 NULL이면 목록이 비어 있으므로 이제 새 노드를 추가하고 이를 헤드로 설정합니다. head → next를 NULL로 추가합니다. 노드에 대한 포인터를 반환합니다.
head가 null이 아닌 경우 head->next = addtoEnd(head->next, data)를 사용하여 노드를 head → next에 추가합니다.
함수 traverseList(SLLNode* head) 헤드부터 순회하고 각 값을 인쇄합니다.
head가 NULL이면 NULL을 인쇄하고 반환합니다.
그렇지 않으면 데이터 값을 인쇄하고 traverseList(head->next)를 사용하여 다음으로 이동합니다.
기본 생성 목록에서 addtoEnd()를 사용하고 traverseList()를 사용하여 목록을 인쇄합니다.
Example
#include <bits/stdc++.h> using namespace std; struct SLLNode { int data; SLLNode* next; }; SLLNode* addtoEnd(SLLNode* head, int data){ if (head == NULL){ SLLNode *nodex = new SLLNode; nodex->data = data; nodex->next = NULL; return nodex; } else{ head->next = addtoEnd(head->next, data); } return head; } void traverseList(SLLNode* head){ if (head == NULL){ cout <<"NULL"; return; } cout << head->data << " -> "; traverseList(head->next); } int main(){ SLLNode* head1 = NULL; head1 = addtoEnd(head1, 1); head1 = addtoEnd(head1, 8); head1 = addtoEnd(head1, 56); head1 = addtoEnd(head1, 12); head1 = addtoEnd(head1, 34); cout<<"Linked List is :"<<endl; traverseList(head1); return 0; }
Output
위 코드를 실행하면 다음과 같은 출력이 생성됩니다
Linked List is : 1 -> 8 -> 56 -> 12 -> 34 -> NULL
위 내용은 C++에서 연결 리스트의 재귀 삽입 및 순회의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











C++ 함수의 재귀 깊이에는 제한이 있습니다. 이 제한을 초과하면 스택 오버플로 오류가 발생합니다. 제한 값은 시스템과 컴파일러에 따라 다르지만 일반적으로 1,000에서 10,000 사이입니다. 솔루션에는 다음이 포함됩니다. 1. 테일 재귀 최적화, 2. 테일 호출, 3. 반복 구현.

예, C++ Lambda 표현식은 std::function을 사용하여 재귀를 지원할 수 있습니다. std::function을 사용하여 Lambda 표현식에 대한 참조를 캡처합니다. 캡처된 참조를 사용하면 Lambda 표현식이 자신을 재귀적으로 호출할 수 있습니다.

SQL에서의 MINUS 사용 및 특정 코드 예 SQL에서 MINUS는 두 결과 집합 간의 차이 연산을 수행하는 데 사용되는 연산자입니다. 두 번째 결과 집합에서와 마찬가지로 첫 번째 결과 집합에서도 동일한 행을 삭제하는 데 사용됩니다. MINUS 연산자가 반환한 결과 집합에는 첫 번째 결과 집합에만 존재하는 행이 포함됩니다. 다음은 특정 코드 예제를 사용하여 MINUS의 사용법을 보여줍니다. "table1"과 "table2"라는 두 개의 테이블이 있고 해당 구조는 다음과 같다고 가정합니다. 테이블 이름: table1 필드

재귀 알고리즘은 함수 자체 호출을 통해 구조화된 문제를 해결하지만 간단하고 이해하기 쉽다는 장점이 있지만 효율성이 떨어지고 스택 오버플로가 발생할 수 있다는 단점이 있습니다. 스택 데이터 구조의 장점은 더 효율적이고 스택 오버플로를 방지한다는 것입니다. 단점은 코드가 더 복잡할 수 있다는 것입니다. 재귀적 또는 비재귀적 선택은 문제와 구현의 특정 제약 조건에 따라 달라집니다.

Java는 강력한 파일 처리 기능을 갖춘 널리 사용되는 프로그래밍 언어입니다. Java에서는 폴더를 탐색하고 모든 파일 이름을 가져오는 것이 일반적인 작업이므로 특정 디렉터리에서 파일을 빠르게 찾고 처리하는 데 도움이 될 수 있습니다. 이 기사에서는 폴더를 탐색하여 모든 파일 이름을 Java로 가져오는 방법을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 재귀적 방법을 사용하여 폴더를 순회할 수 있습니다. 재귀적 방법은 폴더를 효과적으로 순회할 수 있는 자체 호출 방법입니다.

재귀 함수는 문자열 처리 문제를 해결하기 위해 자신을 반복적으로 호출하는 기술입니다. 무한 재귀를 방지하기 위해서는 종료 조건이 필요합니다. 재귀는 문자열 반전 및 회문 검사와 같은 작업에 널리 사용됩니다.

1. wps 소프트웨어를 열고 wps 텍스트 작업 인터페이스로 들어갑니다. 2. 이 인터페이스에서 삽입 옵션을 찾으세요. 3. 삽입 옵션을 클릭하고 편집 영역에서 모양 옵션을 찾으세요. 4. 모양 옵션을 클릭하고 하위 메뉴에서 권장 옵션을 찾으세요. 5. 추천 옵션에서 중국 지도 옵션을 찾아보세요. 6. 중국 지도 옵션을 클릭하고 편집 입력 영역에서 마우스 왼쪽 버튼으로 드래그하여 필요한 중국 지도를 가져옵니다.

재귀는 문제를 해결하기 위해 함수가 자신을 호출할 수 있도록 하는 강력한 기술입니다. C++에서 재귀 함수는 두 가지 핵심 요소, 즉 기본 사례(재귀 중지 시기를 결정함)와 재귀 호출(문제를 여러 단계로 나누는 경우)로 구성됩니다. 더 작은 하위 문제). 기초를 이해하고 계승 계산, 피보나치 수열, 이진 트리 순회 등의 실제 예제를 연습함으로써 재귀적 직관을 구축하고 자신 있게 코드에서 사용할 수 있습니다.
