C 언어의 반복 방법을 사용하여 연결된 목록의 마지막 k 노드를 역순으로 인쇄합니다.
연결리스트의 k개 노드를 역순으로 인쇄해야 합니다. 이 문제를 해결하려면 반복적인 접근 방식을 적용해야 합니다.
반복 메서드는 일반적으로 조건 값이 1 또는 true가 될 때까지 루프를 사용하여 실행됩니다.
목록에 노드 29, 34, 43, 56 및 88이 포함되어 있고 k 값이 2라고 가정하면 출력은 최대 k까지의 예비 노드(예: 56 및 88)가 됩니다.
예
Linked List: 29->34->43->56->88 Input: 2 Output: 56 88
목록에서 마지막 k개 요소를 제거해야 하기 때문에 가장 좋은 방법은 요소가 푸시되는 스택 데이터 구조를 사용하는 것입니다. 이렇게 하면 목록과 시작 요소가 생성됩니다. 스택은 목록의 마지막 요소이고 k번째가 될 때까지 스택에서 팝되어 연결 목록의 마지막 노드를 제공합니다.
아래 코드는 주어진 알고리즘의 C 구현을 보여줍니다.
Algorithm
START Step 1 -> create node variable of type structure Declare int data Declare pointer of type node using *next Step 2 -> create struct node* intoList(int data) Create newnode using malloc Set newnode->data = data newnode->next = NULL return newnode step 3 -> Declare function void rev(struct node* head,int count, int k) create struct node* temp1 = head Loop While(temp1 != NULL) count++ temp1 = temp1->next end Declare int array[count], temp2 = count,i Set temp1 = head Loop While(temp1 != NULL) Set array[--temp2] = temp1->data Set temp1 = temp1->next End Loop For i = 0 and i < k and i++ Print array[i] End Step 4 -> In Main() Create list using struct node* head = intoList(9) Set k=3 and count=0 Call rev(head,count,k) STOP
Example
#include<stdio.h> #include<stdlib.h> // Structure of a node struct node { int data; struct node *next; }; //functon for inserting a new node struct node* intoList(int data) { struct node* newnode = (struct node*)malloc(sizeof(struct node)); newnode->data = data; newnode->next = NULL; return newnode; } // Function to reversely printing the elements of a node void rev(struct node* head,int count, int k) { struct node* temp1 = head; while(temp1 != NULL) { count++; temp1 = temp1->next; } int array[count], temp2 = count,i; temp1 = head; while(temp1 != NULL) { array[--temp2] = temp1->data; temp1 = temp1->next; } for(i = 0; i < k; i++) printf("%d ",array[i]); } int main() { printf("</p><p>reverse of a list is : "); struct node* head = intoList(9); //inserting elements into a list head->next = intoList(76); head->next->next = intoList(13); head->next->next->next = intoList(24); head->next->next->next->next = intoList(55); head->next->next->next->next->next = intoList(109); int k = 3, count = 0; rev(head, count, k); //calling function to print reversely return 0; }
Output
위 프로그램을 실행하면 다음과 같은 출력이 생성됩니다.
rreee위 내용은 C 언어의 반복 방법을 사용하여 연결된 목록의 마지막 k 노드를 역순으로 인쇄합니다.의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











typedef struct는 C 언어에서 구조 사용을 단순화하기 위해 구조 유형 별칭을 만드는 데 사용됩니다. 구조 별칭을 지정하여 기존 구조에 새 데이터 유형의 별칭을 지정합니다. 향상된 가독성, 코드 재사용 및 유형 확인 등의 이점이 있습니다. 참고: 별칭을 사용하기 전에 구조를 정의해야 합니다. 별칭은 프로그램에서 고유해야 하며 선언된 범위 내에서만 유효해야 합니다.

strcpy는 문자열을 다른 문자열에 복사하고, strcat는 문자열을 다른 문자열에 추가합니다. 주요 차이점은 다양한 목적, 다양한 dst 매개변수 처리 및 다양한 보안 고려사항을 포함합니다.

real은 C 언어에서 배정밀도 부동 소수점 숫자를 나타내는 데 사용되는 데이터 유형입니다. 8바이트를 차지하고 소수점 이하 약 15자리의 정밀도를 가지며 범위는 [-1.7976931348623157e+308, 1.7976931348623157e+308]입니다.

복소수 유형은 C 언어에서 실수부와 허수부를 포함하는 복소수를 나타내는 데 사용됩니다. 초기화 형태는 complex_number = 3.14 + 2.71i 이며 실수부분은 creal(complex_number)를 통해, 허수부분은 cimag(complex_number)를 통해 접근할 수 있습니다. 이 유형은 덧셈, 뺄셈, 곱셈, 나눗셈 및 모듈로와 같은 일반적인 수학 연산을 지원합니다. 또한 cpow, csqrt, cexp 및 csin과 같은 복소수 작업을 위한 함수 세트가 제공됩니다.

C 언어에는 지수 연산을 구현하는 두 가지 방법이 있습니다. pow() 함수를 사용하여 첫 번째 매개변수의 두 번째 매개변수의 거듭제곱을 계산합니다. 재귀적으로 또는 반복적으로 구현할 수 있는 사용자 정의 검정력 함수를 정의합니다. 재귀적 방법은 검정력이 0이 될 때까지 계속해서 두 배로 증가합니다. 반복 방법은 루프를 사용하여 밑수를 하나씩 곱합니다.

제한 키워드는 포인터를 통해서만 변수에 액세스할 수 있음을 컴파일러에 알리고 정의되지 않은 동작을 방지하고 코드를 최적화하며 가독성을 향상시키는 데 사용됩니다. 여러 포인터가 동일한 변수를 가리킬 때 정의되지 않은 동작을 방지합니다. 코드를 최적화하기 위해 컴파일러는 제한 키워드를 사용하여 변수 액세스를 최적화합니다. 포인터를 통해서만 변수에 액세스할 수 있음을 표시하여 코드 가독성을 향상시킵니다.

C 언어에서 scanf 함수 오류를 처리하는 방법은 다음과 같습니다. 1. 형식 문자열을 확인합니다. 3. 반환 값을 확인합니다. 4. 오류 처리 기능을 사용합니다. 사용자 정의 오류가 처리됩니다. 오류를 방지하려면 올바른 데이터 유형을 사용하고, 입력의 유효성을 주의 깊게 확인하고, 반환 값을 확인하고, 프로그램의 잠재적인 오류를 처리하십시오.

_Bool은 C 언어에서 true 또는 false 두 가지 값만 포함하는 간단한 데이터 유형입니다. 조건이나 논리식의 결과를 나타내는 데 사용되며 일반적으로 1바이트의 메모리를 차지하며 true 또는 false만 저장할 수 있습니다. 거짓. 거짓 값.
