StackTc 2017-11-30 05:42 采纳率: 90.9%
浏览 819
已采纳

leetcode第二题 add two number 10C求解

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
 class Solution {
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        ListNode root = new ListNode(0);
                ListNode returnNode = root;
        int carry = 0;
        if(l1 == null){
            return l2;
        }
        if(l2 == null){
            return l1;
        }
        while(l1 != null || l2 != null){
            int q = (l1 != null) ? l1.val : 0;
            int p = (l2 != null) ? l2.val : 0;
            int sum = (p + q) + carry;
            carry = (p + q) / 10;
            returnNode = new ListNode(sum % 10);
            returnNode = returnNode.next;
            if(l1 != null) l1 = l1.next;
            if(l2 != null) l2 = l2.next;
        }
        if(carry > 0){
            returnNode.next = new ListNode(carry);
        }
        return returnNode;
    }
}

本人有2个疑点。
1:为什么我的程序不行
2:进位哪里我有点看不懂,比如 【2,4,3】 【2,8,2】 以程序来看结果本人的理解 是【4,2,5,1】 可是期望的结果是【2,2,6】。求算法大神指导。

展开全部

  • 写回答

3条回答 默认 最新

  • qq_41242687 2017-12-01 09:33
    关注

    这里面链表是从个位开始的,到尽头是最高位,所以
    342+182=524 可以表示为链表加法 2->4->3->null + 2->8->1->null = 4->2->5->null
    你的程序有几个问题(如果不是笔误):
    1. carry 应该是 sum/10,或者说 (p+q+carry)/10,你写 (p+q)/10 是不够的。
    2. 注意 returnNode 要挪到 next 上。
    3. returnNode 一直在沿着链表往后挪,你不能返回 returnNode 了,你得返回 root(的 next)才是表头。
    4. 注意 next 的初始化。

    程序如下,亲测有效:

    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
    ListNode root = new ListNode(0);
    ListNode returnNode = root;
    returnNode.next = null;
    int carry = 0;
    if(l1 == null){
    return l2;
    }
    if(l2 == null){
    return l1;
    }
    while(l1 != null || l2 != null){
    int q = (l1 != null) ? l1.val : 0;
    int p = (l2 != null) ? l2.val : 0;
    int sum = (p + q) + carry;
    carry = sum / 10;
    returnNode.next = new ListNode(sum % 10);
    returnNode = returnNode.next;
    returnNode.next = null;
    if(l1 != null) l1 = l1.next;
    if(l2 != null) l2 = l2.next;
    }
    if(carry > 0){
    returnNode.next = new ListNode(carry);
    returnNode = returnNode.next;
    returnNode.next = null;
    }
    return root.next;
    }

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 Android系统裁剪
  • ¥15 雄安新区高光谱数据集的下载网址打不开
  • ¥66 android运行时native和graphics内存详细信息获取
  • ¥100 求一个c#通过CH341读取数据的Demo,能够读取指定地址值的功能
  • ¥15 rk3566 Android11 USB摄像头 微信
  • ¥15 torch框架下的强化学习DQN训练奖励值浮动过低,希望指导如何调整
  • ¥35 西门子博图v16安装密钥提示CryptAcquireContext MS_DEF_PROV Error of containger opening
  • ¥15 mes系统扫码追溯功能
  • ¥40 selenium访问信用中国
  • ¥20 在搭建fabric网络过程中遇到“无法使用新的生命周期”的报错
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部