Modified Odd Even Linked List
unknown
plain_text
a year ago
2.3 kB
1
Indexable
Never
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next = next; } * } */ class Solution { public static ListNode insertEnd(ListNode head, int x) { ListNode temp = new ListNode(x); if (head == null) { return temp; } ListNode curr = head; while (curr.next != null) { curr = curr.next; } curr.next = temp; return head; } public static int lenLL(ListNode head) { ListNode curr = head; int length = 0; while (curr != null) { length++; curr = curr.next; } return length; } public static ListNode oddEvenList(ListNode head) { int lenOfLL = lenLL(head); int[] oddElements = new int[lenOfLL]; int[] evenElements = new int[lenOfLL]; ListNode curr = head; int pos = 1; int oddIdx = 0, evenIdx = 0; while (curr != null) { if ((pos % 2) != 0) { oddElements[oddIdx] = curr.val; oddIdx++; pos++; curr = curr.next; continue; } else if ((pos % 2) == 0) { evenElements[evenIdx] = curr.val; evenIdx++; curr = curr.next; pos++; continue; } } ListNode curr2 = head; int firstVal = curr2.val; ListNode head2 = null; //ListNode finalHead = null; int idx1 = 0, idx2 = 0; head2 = null; idx1 = 0; while (oddElements[idx1] > 0) { head2 = insertEnd(head2, oddElements[idx1]); idx1++; continue; } idx2 = 0; while (evenElements[idx2] > 0) { head2 = insertEnd(head2, evenElements[idx2]); idx2++; continue; } return head2; } }