Data Structures & Algorithms

Leetcode 24 Swap Nodes in Pairs Java Solution

Given a linked list, swap every two adjacent nodes and return its head.

You may not modify the values in the list’s nodes, only nodes itself may be changed.

Example:

Given 1->2->3->4, you should return the list as 2->1->4->3.

Solution 1:
public class Solution {
    public ListNode swapPairs(ListNode head) {
        if(head == null || head.next == null) return head;
        int count = 1;
           ListNode current = head;
           ListNode temp = head;
           ListNode returnNode = head.next;
           while(current.next!=null){
               if(getNextNode(current)!=null && count == 1){
               ListNode nextNode = getNextNode(current);
               current.next = nextNode.next;
               nextNode.next = current;
               temp = current;
               if(current.next!=null){
               current = current.next;
               }
               count++;
               }else if(getNextNode(current)!=null && count > 1){
                   ListNode nextNode = getNextNode(current);
               current.next = nextNode.next;
               nextNode.next = current;
               temp.next  = nextNode;
               temp = current;
               if(current.next!=null){
               current = current.next;
               }
               }
               
           }
           return returnNode;
               
    }
    
    public ListNode getNextNode(ListNode head){
        return head.next;
    }
}
rajendra

Recent Posts

Largest Unique Number Java Solution

Question : Given an array of integers A, return the largest integer that only occurs once.…

10 months ago

Jump Search Algorithm In Java

Jump search algorithm is a pretty new algorithm to search for an element in a…

1 year ago

Knuth Morris Pratt Pattern Search Algorithm

What is Knuth Morris Pratt or KMP algorithm ? KMP is an algorithm which is…

1 year ago

Binary Search Algorithm In Java

Binary Search is a Logarithmic search which finds the target element in a sorted array…

1 year ago

Leetcode Integer to Roman Java Solution

Roman numerals are represented by seven different symbols: I, V, X, L, C, D and M. Symbol Value I 1 V 5 X…

2 years ago

Leetcode Container With Most Water Java Solution

Given n non-negative integers a1, a2, ..., an , where each represents a point at coordinate (i, ai). n vertical lines are drawn such…

2 years ago

This website uses cookies.