328. Odd Even Linked List

mail@pastecode.io avatar
unknown
plain_text
a year ago
4.1 kB
4
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 boolean firstInOdd(int firstVal, int[] oddElements) {
        int key = firstVal;
        boolean ret = false;
        for (int i = 0; i < oddElements.length; i++) {
            if (key == oddElements[i]) {
                ret = true;
                break;
            } else {
                continue;
            }
        }
        return ret;
    }

    public static boolean firstInEven(int firstVal, int[] evenElements) {
        int key = firstVal;
        boolean ret = false;
        for (int i = 0; i < evenElements.length; i++) {
            if (key == evenElements[i]) {
                ret = true;
                break;
            } else {
                continue;
            }
        }
        return ret;
    }

    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 firstVal = head.val;
        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;
            }
        }
        for (int i = 0; i < evenElements.length; i++) {
            System.out.print(evenElements[i] + " ");
        }
        System.out.println();
        for (int i = 0; i < oddElements.length; i++) {
            System.out.print(oddElements[i] + " ");
        }
        //ListNode curr2 = head;
        //int firstVal = curr2.val;
        ListNode head2 = null;
        ListNode finalHead = null;
        int idx1 = 0, idx2 = 0;
        if (firstInEven(firstVal, evenElements)) {
            System.out.println("Even elements first");
            head2 = null;
            while (evenElements[idx1] != 0) {
                head2 = insertEnd(head2, evenElements[idx1]);
                idx1++;
                continue;
            }
            idx2 = 0;
            while (oddElements[idx2] != 0) {
                head2 = insertEnd(head2, oddElements[idx2]);
                idx2++;
                continue;
            }
            finalHead = head2;
        } else if (firstInOdd(firstVal, oddElements)) {
            System.out.println("Odd element first");
            head2 = null;
            idx1 = 0;
            while (oddElements[idx1] > 0) {
                head2 = insertEnd(head2, oddElements[idx1]);
                idx1++;
                continue;
            }
            // printlist(head2);
            idx2 = 0;
            while (evenElements[idx2] > 0) {
                head2 = insertEnd(head2, evenElements[idx2]);
                idx2++;
                continue;
            }
            // printlist(head2);
            finalHead = head2;
        }
        return finalHead;
    }
}