Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3665965
  • 博文数量: 365
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2522
  • 用 户 组: 普通用户
  • 注册时间: 2019-10-28 13:40
文章分类

全部博文(365)

文章存档

2023年(8)

2022年(130)

2021年(155)

2020年(50)

2019年(22)

我的朋友

分类: Java

2021-06-22 17:19:44

/**

 * Created by TanJiaJun on 2021/6/5.

 * 2. 两数相加(Add Two Numbers

 * 难度:中等

 *

 * @see Add Two Numbers

 */

class AddTwoNumbers {

    public static void main(String[] args) {

        // 示例一

        System.out.print("示例一:");

        Node firstNode =

                new Node(2,

                        new Node(4,

                                new Node(3)));

        Node secondNode =

                new Node(5,

                        new Node(6,

                                new Node(4)));

        printNode(addTwoNumbers(firstNode, secondNode));

        System.out.print("\n");

        // 示例二

        System.out.print("示例二:");

        Node thirdNode = new Node(0);

        Node fourthNode = new Node(0);

        printNode(addTwoNumbers(thirdNode, fourthNode));

        System.out.print("\n");

        // 示例三

        System.out.print("示例三:");

        Node fifthNode =

                new Node(9,

                        new Node(9,

                                new Node(9,

                                        new Node(9,

                                                new Node(9,

                                                        new Node(9,

                                                                new Node(9)))))));

        Node sixthNode =

                new Node(9,

                        new Node(9,

                                new Node(9,

                                        new Node(9))));

        printNode(addTwoNumbers(fifthNode, sixthNode));

        System.out.print("\n");

        // 示例四

        System.out.print("示例四:");

        Node seventhNode = new Node(2);

        Node eightNode = new Node(8);

        printNode(addTwoNumbers(seventhNode, eightNode));

    }

    /**

     * 时间复杂度:O(Max(m, n)),其中m是第一个结点的长度,n是第二个结点的长度

     * 空间复杂度:O(1)

     *

     * @param firstNode  第一个结点

     * @param secondNode 第二个结点

     * @return 结果

     */

    private static Node addTwoNumbers(Node firstNode, Node secondNode) {

        Node dummyNode = new Node(-1);

        Node node = dummyNode;

        int carry = 0;

        // 遍历两个链表

        while (firstNode != null || secondNode != null) {

            // 如果两个链表的长度不相同的话,就在短的链表的后面通过添加若干个0

            int firstValue = firstNode != null ? firstNode.item : 0;

            int secondValue = secondNode != null ? secondNode.item : 0;

            int value = firstValue + secondValue + carry;

            int newItem = value % 10;

            // 相加后的进位值通过carry来存储

            carry = value / 10;

            Node newNode = new Node(newItem);

            if (firstNode != null) {

                firstNode = firstNode.next;

            }

            if (secondNode != null) {

                secondNode = secondNode.next;

            }

            // 如果在遍历完这两个链表后,carry的值大于0,那么就应该在链表的后面增加一个新的结点来存储这个值

            if (firstNode == null && secondNode == null && carry > 0) {

                newNode.next = new Node(carry);

            }

            node.next = newNode;

            node = node.next;

        }

        return dummyNode.next;

    }

    /**

     * 打印结点

     *

     * @param node 结点

     */

    private static void printNode(Node node) {

        System.out.print("[");

        while (node != null) {

            System.out.print(node.item);

            node = node.next;

            if (node != null) {

                System.out.print(",");

            }

        }

        System.out.print("]");

    }

    private static class Node {

        int item;

        Node next;

        Node(int item) {

            this.item = item;

        }

        Node(int item, Node next) {

            this.item = item;

            this.next = next;

        }

    }

}

阅读(899) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~