단일 연결 목록이 제공되며 해당 목록에서 마지막 노드를 제거해야 합니다. 이 문제에서 우리는 주어진 목록을 순회하고 단순히 마지막 노드를 제거할 것입니다.
해결책을 찾기 위한 접근 방식
이 접근 방식에서는 주어진 목록을 살펴보고 이전 노드와 현재 노드를 추적합니다. 이제 현재 노드가 마지막 노드가 되면 NULL 옆에 있는 이전 ->을 변경하고 현재 노드를 삭제합니다.
예시
#include <iostream> using namespace std; struct Node { int data; struct Node* next; }; void push(struct Node** ref, int new_data) { // pushing the node struct Node* new_n = new Node; new_n->data = new_data; new_n->next = (*ref); (*ref) = new_n; } int main() { Node* head = NULL; push(&head, 12); push(&head, 29); push(&head, 11); push(&head, 23); push(&head, 8); auto curr = head, prev = head; if (!curr || !curr -> next) // if list only has one element or the list is empty cout << "Empty\n"; else { while (curr) { // while curr != NULL if (!curr -> next) { prev -> next = NULL; delete(curr); // freeing the space break; } prev = curr; curr = curr -> next; // moving to the next node } } for (Node* temp = head; temp != NULL; temp = temp->next) // printing the data cout << temp->data << " "; return 0; }
출력
8 23 11 29
위 코드 설명
이 접근 방식에서 우리는 현재 노드와 이전 노드를 추적하면서 배열을 순회합니다. 이제 현재 노드가 마지막 노드가 되면 NULL 옆에 있는 이전 ->을 변경하고 현재 노드를 삭제합니다. 주어진 프로그램의 전체 시간 복잡도는 O(N)이며, 여기서 N은 주어진 목록의 크기입니다.
시간 복잡도 - O(N)
N:배열의 크기
결론
이 기사에서는 주어진 연결 목록에서 마지막 노드를 제거하는 문제를 해결합니다. 우리는 또한 이 문제에 대한 C++ 프로그램과 우리가 해결한 완전한 접근 방식을 배웠습니다. C, Java, python 및 기타 언어와 같은 다른 언어로 동일한 프로그램을 작성할 수 있습니다. 이 기사가 도움이 되기를 바랍니다.