연결리스트를 역방향으로 변환하는 C 프로그램
이 질문에는 연결 목록이 제공됩니다. 우리의 임무는 연결된 목록을 뒤집는 프로그램을 만드는 것입니다.
이 프로그램은 주어진 연결 리스트를 반전하고 반전된 연결 리스트를 반환합니다.
연결된 목록은 항목을 포함하는 연결된 시퀀스입니다. 각 링크에는 다른 링크에 대한 연결이 포함되어 있습니다.
Example
9 -> 32 -> 65 -> 10 -> 85 -> NULL
Reverse linked list는 연결리스트의 링크를 반대로 바꾸어 연결리스트를 만드는 것입니다. 연결 리스트의 헤드 노드는 연결 리스트의 마지막 노드가 되고, 마지막 노드는 헤드 노드가 됩니다.
Example
위 연결리스트로 구성된 역연결리스트 −
85 -> 10 -> 65 -> 32 -> 9 -> NULL
주어진 연결리스트를 역전시키기 위해 포인터 3개를 추가로 사용하여 처리하겠습니다. 이러한 포인터는 이전, 이후 및 현재입니다.
처음에는 이전과 이후를 모두 NULL로 설정하고 현재를 연결 목록의 선두로 설정합니다.
이후 초기 연결리스트의 NULL에 도달할 때까지 반복합니다. 그런 다음 다음을 수행하세요.
after = current -> next current -> next = previous previous = current current = after
이제 연결 목록을 역전시키는 프로그램을 만들어 보겠습니다. 이 프로그램을 작성하는 방법에는 두 가지가 있습니다. 하나는 반복적이고 다른 하나는 재귀적입니다.
연결된 목록을 뒤집는 프로그램(꼬리 재귀적 방법)
예제
Demonstration
#include <stdio.h> struct Node { int data; struct Node* next; }; Node* insertNode(int key) { Node* temp = new Node; temp->data = key; temp->next = NULL; return temp; } void tailRecRevese(Node* current, Node* previous, Node** head){ if (!current->next) { *head = current; current->next = previous; return; } Node* next = current->next; current->next = previous; tailRecRevese(next, current, head); } void tailRecReveseLL(Node** head){ if (!head) return; tailRecRevese(*head, NULL, head); } void printLinkedList(Node* head){ while (head != NULL) { printf("%d ", head->data); head = head->next; } printf("</p><p>"); } int main(){ Node* head1 = insertNode(9); head1->next = insertNode(32); head1->next->next = insertNode(65); head1->next->next->next = insertNode(10); head1->next->next->next->next = insertNode(85); printf("Linked list : \t"); printLinkedList(head1); tailRecReveseLL(&head1); printf("Reversed linked list : \t"); printLinkedList(head1); return 0; }
Output
Linked list : 9 32 65 10 85 Reversed linked list : 85 10 65 32 9
연결된 목록을 뒤집는 프로그램(반복 방법)
Example
실시간 시연
#include <stdio.h> struct Node { int data; struct Node* next; Node(int data){ this->data = data; next = NULL; } }; struct LinkedList { Node* head; LinkedList(){ head = NULL; } void interReverseLL(){ Node* current = head; Node *prev = NULL, *after = NULL; while (current != NULL) { after = current->next; current->next = prev; prev = current; current = after; } head = prev; } void print() { struct Node* temp = head; while (temp != NULL) { printf("%d ", temp-> data); temp = temp->next; } printf("</p><p>"); } void push(int data){ Node* temp = new Node(data); temp->next = head; head = temp; } }; int main() { LinkedList linkedlist; linkedlist.push(85); linkedlist.push(10); linkedlist.push(65); linkedlist.push(32); linkedlist.push(9); printf("Linked List : \t"); linkedlist.print(); linkedlist.interReverseLL(); printf("Reverse Linked List : \t"); linkedlist.print(); return 0; }
출력
Linked List : 9 32 65 10 85 Reverse Linked List : 85 10 65 32 9
위 내용은 연결리스트를 역방향으로 변환하는 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단계 - 시작 2단계 - 런타임에 로마 숫자 읽기 3단계 - 길이: = strlen(roman) 4단계 - i=0에서 길이-1까지 단계 4.1-switch(roman[i]) 4.1.1단계-case'm': &nbs

사전식 문자열 비교는 문자열이 사전 순서로 비교된다는 것을 의미합니다. 예를 들어 'apple'과 'appeal'이라는 두 개의 문자열이 있는 경우 'app'의 처음 세 문자가 동일하므로 첫 번째 문자열이 마지막에 옵니다. 그러면 첫 번째 문자열의 문자는 'l'이고 두 번째 문자열의 네 번째 문자는 'e'입니다. 'e'는 'l'보다 짧기 때문에 사전순으로 정렬하면 e가 먼저 나옵니다. 문자열은 정렬되기 전에 사전순으로 비교됩니다. 이 기사에서는 C++를 사용하여 두 문자열을 사전순으로 비교하는 다양한 기술을 살펴보겠습니다. C++ 문자열에서 Compare() 함수 사용하기 C++string 개체에는 Compare() 함수가 있습니다.

쌍곡선 함수는 원 대신 쌍곡선을 사용하여 정의되며 일반 삼각 함수와 동일합니다. 제공된 각도(라디안)에서 쌍곡사인 함수의 비율 매개변수를 반환합니다. 그러나 반대로 하십시오. 즉, 반대로 하십시오. 쌍곡선 사인으로부터 각도를 계산하려면 쌍곡선 역사인 연산과 같은 역쌍곡선 삼각법 연산이 필요합니다. 이 과정에서는 라디안 단위의 쌍곡선 사인 값을 사용하여 각도를 계산하기 위해 C++에서 쌍곡선 역사인(asinh) 함수를 사용하는 방법을 보여줍니다. 쌍곡선 아크사인 연산은 다음 공식 -$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})}을 따릅니다. 여기서\:In\:은\:자연 로그\:(log_e\:k)

연결된 목록은 동적 메모리 할당을 사용합니다. 즉, 그에 따라 메모리가 늘어나고 줄어듭니다. 이는 노드 모음으로 정의됩니다. 여기서 노드는 데이터와 링크라는 두 부분으로 구성됩니다. 데이터, 링크, 연결리스트는 다음과 같이 표현됩니다. - 연결리스트의 종류 연결리스트에는 다음과 같은 4가지 종류가 있습니다. - 단일 연결리스트 / 단일 연결리스트 이중 / 이중 연결리스트 원형 단일 연결리스트 순환 이중 연결리스트 연결된 목록의 길이를 찾는 재귀 메서드 논리는 -intlength(node *temp){ if(temp==NULL) returnl{&n;

맵은 각 요소가 두 값, 즉 키 값과 맵 값의 쌍인 C++의 특수한 유형의 컨테이너입니다. 키 값은 각 항목을 인덱싱하는 데 사용되며 매핑된 값은 키와 연결된 값입니다. 매핑된 값이 고유한지 여부에 관계없이 키는 항상 고유합니다. C++에서 맵 요소를 인쇄하려면 반복자를 사용해야 합니다. 항목 집합의 요소는 반복자 개체로 표시됩니다. 반복자는 주로 배열 및 기타 유형의 컨테이너(예: 벡터)와 함께 사용되며 특정 범위 내의 특정 요소를 식별하는 데 사용할 수 있는 특정 작업 집합을 가지고 있습니다. 반복자는 범위나 컨테이너에 있는 다양한 요소를 참조하기 위해 증가하거나 감소할 수 있습니다. 반복자는 범위에 있는 특정 요소의 메모리 위치를 가리킵니다. 반복자를 사용하여 C++에서 지도 인쇄하기 먼저, 정의하는 방법을 살펴보겠습니다.

이름 바꾸기 기능은 파일이나 디렉토리를 이전 이름에서 새 이름으로 변경합니다. 이 작업은 이동 작업과 유사합니다. 따라서 이 이름 바꾸기 기능을 사용하여 파일을 이동할 수도 있습니다. 이 함수는 stdio.h 라이브러리 헤더 파일에 있습니다. rename 함수의 구문은 다음과 같습니다. intrename(constchar*oldname,constchar*newname); rename() 함수의 함수는 두 개의 매개변수를 허용합니다. 하나는 oldname이고 다른 하나는 newname입니다. 두 매개변수는 모두 파일의 이전 이름과 새 이름을 정의하는 상수 문자에 대한 포인터입니다. 파일 이름이 성공적으로 변경되면 0을 반환하고, 그렇지 않으면 0이 아닌 정수를 반환합니다. 이름 바꾸기 작업 중

현대 과학은 복수의 개념에 크게 의존하고 있는데, 이는 17세기 초 Girolamo Cardano가 처음으로 확립한 것으로, 그는 16세기에 이를 도입했습니다. 복소수의 공식은 a+ib입니다. 여기서 a는 html 코드이고 b는 실수입니다. 복소수는 실수부 <a>와 허수부(<ib>)의 두 부분으로 구성됩니다. i 또는 iota의 값은 √-1입니다. C++의 복수형 클래스는 복소수를 나타내는 데 사용되는 클래스입니다. C++의 복소수 클래스는 여러 복소수 연산을 표현하고 제어할 수 있습니다. 복수의 숫자 표시를 어떻게 표현하고 제어하는지 살펴보겠습니다. imag() 멤버 함수 위에서 언급했듯이 복소수는 실수부와 허수부로 구성됩니다. 실제 부분을 표시하려면 real()을 사용합니다.

문자열이나 문자를 사용하는 것은 일부 논리 프로그래밍 문제를 해결할 때 때때로 매우 유용합니다. 문자열은 문자 모음으로, ASCII 값의 기호를 보유하는 데 사용되는 1바이트 데이터 유형입니다. 기호는 영문자, 숫자, 특수문자가 될 수 있습니다. 이번 글에서는 C++를 이용하여 문자가 영문자인지 알파벳인지 확인하는 방법을 알아보겠습니다. isalpha() 함수 확인 숫자가 문자인지 확인하려면 ctype.h 헤더 파일에서 isalpha() 함수를 사용할 수 있습니다. 문자를 입력으로 받아 알파벳이면 true를 반환하고, 그렇지 않으면 false를 반환합니다. 이 함수의 사용법을 이해하기 위해 다음 C++ 구현을 살펴보겠습니다. 예제의 중국어 번역은 다음과 같습니다.
