ধরুন আমাদের একটি এককভাবে লিঙ্কযুক্ত তালিকা রয়েছে, আমাদেরকে জোড় নোড দ্বারা অনুসরণ করে সমস্ত বিজোড় নোডকে একসাথে গোষ্ঠী করতে হবে। এখানে আমরা নোডের অবস্থানের কথা বলছি না নোডের মান সম্পর্কে। আমরা এটা জায়গায় করার চেষ্টা করা উচিত. সুতরাং যদি নোডগুলি [1,22,13,14,25] হয়, ফলাফল হবে [1,13,25,22,14]
এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -
- যদি হেড নাল হয় বা হেডের পরেরটি শূন্য হয়, তাহলে হেড রিটার্ন করুন
- head1 :=head, head2 :=মাথার পরের, head_beg :=মাথার পাশে
- যখন head2 এর পরেরটি নাল নয় এবং এর পরেরটি (হেডের পরেরটি নাল নয়)
- head1 এর পরের :=head2 এর পরবর্তী
- head2 এর পরের =(মাথার পরের)
- head1 :=head1 এর পরের এবং head2 :=head2 এর পরের
- যদি head2 এর পরবর্তী শূন্য না হয়
- head1 এর পরের :=head2 এর পরবর্তী
- head1 :=head1 এর পরবর্তী
- head1 এর পরের :=head2_beg এবং head2 এর পরের =শূন্য
- রিটার্ন হেড
আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -
উদাহরণ
class ListNode:
def __init__(self, data, next = None):
self.val = data
self.next = next
def make_list(elements):
head = ListNode(elements[0])
for element in elements[1:]:
ptr = head
while ptr.next:
ptr = ptr.next
ptr.next = ListNode(element)
return head
def print_list(head):
ptr = head
print('[', end = "")
while ptr:
print(ptr.val, end = ", ")
ptr = ptr.next
print(']')
class Solution(object):
def oddEvenList(self, head):
if head == None or head.next ==None:
return head
head1=head
head2,head2_beg= head.next,head.next
while head2.next!= None and head2.next.next!= None:
head1.next = head2.next
head2.next = head2.next.next
head1 = head1.next
head2 = head2.next
if head2.next!=None:
head1.next = head2.next
head1 = head1.next
head1.next = head2_beg
head2.next = None
return head
ob1 = Solution()
head = make_list([1,22,13,14,25])
print_list(ob1.oddEvenList(head)) ইনপুট
[1,22,13,14,25]
আউটপুট
[1, 13, 25, 22, 14, ]