java递归实现给出两个 非空 的链表用来表示两个非负的整数

题目:给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。

您可以假设除了数字 0 之外,这两个数都不会以 0 开头。

示例:

输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807

解答代码:创建了一个节点的数据结构的类和另一个实现相加算法的类。

package net.evecom;


/**
 * Created by 76549 on 2019-05-08.
 */
public class AddNumber {
    /**
     * 递归实现链表想加
     * @param ln1
     * @param ln2
     * @param carry
     * @return
     */
    public static LinkNode addLinkNode(LinkNode ln1, LinkNode ln2, int carry) {
        if (ln1 == null) ln1=new LinkNode(0);
        if (ln2 == null) ln2 =new LinkNode(0);
        LinkNode rLinkNode = new LinkNode(0);
        int total = ln1.value + ln2.value+carry;
        rLinkNode.value = total % 10;
        carry = total / 10;
        if (ln1.nextLinkNode != null || ln2.nextLinkNode != null||carry>0) {
            rLinkNode.nextLinkNode = addLinkNode(ln1.nextLinkNode, ln2.nextLinkNode, carry);
        }
        return rLinkNode;
    }

    public static void main(String[] args) {
        //节点1数字为719
        LinkNode ln1a = new LinkNode(9);
        LinkNode ln11b = new LinkNode(1);
        LinkNode ln1c = new LinkNode(7);
        ln1a.nextLinkNode = ln11b;
        ln11b.nextLinkNode = ln1c;

        //节点1数字为627
        LinkNode ln2a = new LinkNode(7);
        LinkNode ln2b = new LinkNode(2);
        LinkNode ln2c = new LinkNode(6);
        ln2a.nextLinkNode = ln2b;
        ln2b.nextLinkNode = ln2c;

        LinkNode rLinkNode = AddNumber.addLinkNode(ln1a, ln2a, 0);
        System.out.println("逆序得到"+rLinkNode.toString());
    }
}


package net.evecom;

/**链表结构
 * Created by 76549 on 2019-05-08.
 */
public class LinkNode {
    int value;//本节点值
    LinkNode nextLinkNode;//下一节点
    public LinkNode(int value) {
        this.value = value;
    }

    /**
     * 逆向输出结果值
     * @return
     */
    public String toString() {
        StringBuffer s = new StringBuffer();
        s.append(value);
        LinkNode n = nextLinkNode;
        while (n != null) {
            s.append(n.value);
            n = n.nextLinkNode;
        }
        return s.toString();
    }
}

结果显示:6431,反转过来就是1346
java递归实现给出两个 非空 的链表用来表示两个非负的整数_第1张图片

你可能感兴趣的:(算法)