算法初级——打印两个有序链表的公共部分

打印两个有序链表的公共部分
【题目】 给定两个有序链表的头指针head1和head2,打印两个链表的公共部分。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
public class 打印有序链表公共部分 {
   
    public static class Node {
        public int value;
        public Node next;
        public Node(int data) {
            this.value = data;
        }
    }

    public static void main(String[] args) {
        Node node1 = new Node(2);
        node1.next = new Node(3);
        node1.next.next = new Node(5);
        node1.next.next.next = new Node(6);

        Node node2 = new Node(1);
        node2.next = new Node(2);
        node2.next.next = new Node(5);
        node2.next.next.next = new Node(7);
        node2.next.next.next.next = new Node(8);

        printLinkedList(node1);
        printLinkedList(node2);
        printCommonPart(node1, node2);
    }

    private static void printCommonPart(Node node1, Node node2) {
        while (node1 != null && node2 != null) {
        if(node1.value == node2.value) {
            System.out.print(node1.value);
            node1 = node1.next;
            node2 = node2.next;
        }else if(node1.value > node2.value) {
            node2 = node2.next;
        }else {
            node1 = node1.next;
        }
        }
    }

    private static void printLinkedList(Node node) {
        while(node != null) {
            System.out.print(node.value);
            node = node.next;
        }
        System.out.println();
    }

}
0 条评论
发表一条评论