मान लें कि हमारे पास एक लिंक्ड सूची है। हमें हर दो आसन्न नोड्स को स्वैप करना होगा और उसके सिर को वापस करना होगा। बाधा यह है कि हम नोड्स के मूल्य को संशोधित नहीं कर सकते हैं, केवल नोड को ही बदला जा सकता है। तो अगर सूची [1,2,3,4] की तरह है, तो परिणामी सूची [2,1,4,3]
होगीइसे हल करने के लिए, हम इन चरणों का पालन करेंगे -
- यदि सिर मौजूद नहीं है, तो सिर वापस करें
- पहला:=सिर, दूसरा:=सिर के आगे, डमी एक नया नोड है जिसका मान -1 है
- डमी के आगे :=पहला, और पिछला :=डमी
- जबकि दूसरा शून्य नहीं है
- अस्थायी:=सेकंड के आगे
- पहले के आगे :=दूसरे के बाद
- दूसरे के अगले:=पहले
- पिछला के आगे :=सेकंड
- पिछला :=पहले
- यदि अस्थायी शून्य नहीं है, तो पहला:=अस्थायी और दूसरा:=अगला तापमान, अन्यथा विराम
- डमी के आगे वापसी
उदाहरण(C++)
एक बेहतर समझ प्राप्त करने के लिए आइए निम्नलिखित कार्यान्वयन को देखें -
#include <bits/stdc++.h> using namespace std; class ListNode{ public: int val; ListNode *next; ListNode(int data){ val = data; next = NULL; } }; ListNode *make_list(vector<int> v){ ListNode *head = new ListNode(v[0]); for(int i = 1; i<v.size(); i++){ ListNode *ptr = head; while(ptr->next != NULL){ ptr = ptr->next; } ptr->next = new ListNode(v[i]); } return head; } void print_list(ListNode *head){ ListNode *ptr = head; cout << "["; while(ptr->next){ cout << ptr->val << ", "; ptr = ptr->next; } cout << "]" << endl; } class Solution { public: ListNode* swapPairs(ListNode* head) { if(!head)return head; ListNode* first= head; ListNode* second = head->next; ListNode* dummy = new ListNode(-1); dummy->next = first; ListNode* prev = dummy; while(second){ ListNode* temp = second->next; first->next = second->next; second->next = first; prev->next = second; prev = first; if(temp){ first = temp; second = temp ->next; } else break; } return dummy->next; } }; main(){ Solution ob; vector<int> v = {1,2,3,4,5,6,7,8}; ListNode *head = make_list(v); print_list(ob.swapPairs(head)); }
इनपुट
[1,2,3,4,5,6,7,8]
आउटपुट
[2,1,4,3,6,5,8,7]