题解 | #链表相加(二)#

链表相加(二)

http://www.nowcoder.com/practice/c56f6c70fb3f4849bc56e33ff2a50b6b

import java.util.*;

/*
 * public class ListNode {
 *   int val;
 *   ListNode next = null;
 * }
 */

/**
1.栈方法,LinkedList实现了栈的接口,可以当做栈使用,还能存储ListNode,不存在类型冲突
    1.首先定义两个LinkedList,分别将数据存入其中
    2.定义新的链表及相关辅助结点head,cur,定义进位
    3一个个取出进行操作,循环条件为栈不为空,且进位不为0
    4.移动链表,改变指针位置,实现新链表的输出并返回头结点,既最新结点
    
    代码如下:
    public class Solution {
    /**
     * 
     * @param head1 ListNode类 
     * @param head2 ListNode类 
     * @return ListNode类
    public ListNode addInList (ListNode head1, ListNode head2) {
        // write code here
         //反转链表
      LinkedList<Integer> stack1=new LinkedList<>();
      LinkedList<Integer> stack2=new LinkedList<>();
     //将链表放入栈中
        ListNode a=head1;//定义辅助结点,遍历
        ListNode b=head2;
        while(a!=null){
            stack1.push(a.val);
            a=a.next;
        }
        
         while(b!=null){
            stack2.push(b.val);
            b=b.next;
        }
        
        int carry=0;//进位
        ListNode head=null;
        ListNode cur=null;
        while(!stack1.isEmpty()||!stack2.isEmpty()||carry!=0){
            int x=stack1.isEmpty()?0:stack1.pop();
            int y=stack2.isEmpty()?0:stack2.pop();
            int sum=x+y+carry;
            carry=sum/10;//跟新进位
            head=new ListNode(sum%10);
            head.next=cur;
            cur=head;//跟新结点位置,相当于从后往前加入结点
        }
        return head;  
    }
}
   
方法2:先逆序,再相加
        1.定义一个逆序链表的函数,分别是实现链表的逆序
        2.遍历链表,进行相加,条件依旧是链表不为空且进位不为0
        3.反向添加结点,并返回;
        代码如下:
        import java.util.*;
public class Solution {
    /**
     * 
     * @param head1 ListNode类 
     * @param head2 ListNode类 
     * @return ListNode类
     
    public ListNode addInList (ListNode head1, ListNode head2) {
        // write code here
        //反转两个链表
        head1=reverseList(head1);
        head2=reverseList(head2);
        ListNode head=null;//添加表头
        ListNode cur=null;//辅助遍历结点
        int carry=0;
        while(head1!=null||head2!=null||carry!=0){
            int x=head1==null?0:head1.val;
            int y=head2==null?0:head2.val;
            int sum=x+y+carry;
            carry=sum/10;
            cur=new ListNode(sum%10);
            cur.next=head;//反向添加结点
            head=cur;
            //移动链表
            if(head1!=null){
                head1=head1.next;
            }
             if(head2!=null){
                head2=head2.next;
            }
        }
        
        return cur;  
    }
       //反转链表
     public ListNode reverseList(ListNode pHead){
         //定义一个表头
         ListNode head=null;
         ListNode cur=pHead;
         while(cur!=null){
             ListNode temp=cur.next;//保存下一结结点
             cur.next=head;//反转链表
             //更新结点位置
             head=cur;
             cur=temp;
         }
         return head;
     }   
}
        
        
   
*/
import java.util.*;
public class Solution {
    /**
     * 
     * @param head1 ListNode类 
     * @param head2 ListNode类 
     * @return ListNode类
     */
    public ListNode addInList (ListNode head1, ListNode head2) {
        // write code here
        //反转两个链表
        head1=reverseList(head1);
        head2=reverseList(head2);
        ListNode head=null;//添加表头
        ListNode cur=null;//辅助遍历结点
        int carry=0;
        while(head1!=null||head2!=null||carry!=0){
            int x=head1==null?0:head1.val;
            int y=head2==null?0:head2.val;
            int sum=x+y+carry;
            carry=sum/10;
            cur=new ListNode(sum%10);
            cur.next=head;//反向添加结点
            head=cur;
            //移动链表
            if(head1!=null){
                head1=head1.next;
            }
             if(head2!=null){
                head2=head2.next;
            }
        }
        
        return cur;  
    }
       //反转链表
     public ListNode reverseList(ListNode pHead){
         //定义一个表头
         ListNode head=null;
         ListNode cur=pHead;
         while(cur!=null){
             ListNode temp=cur.next;//保存下一结结点
             cur.next=head;//反转链表
             //更新结点位置
             head=cur;
             cur=temp;
         }
         return head;
     }   
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
2025-12-17 16:48
今天九点半到公司,我跟往常一样先扫了眼电脑,屁活儿没有。寻思着没事干,就去蹲了个厕所,回来摸出手机刷了会儿。结果老板刚好路过,拍了我一下说上班别玩手机,我吓得赶紧揣兜里。也就过了四十分钟吧,我的直属领导把我叫到小隔间,上来就给我一句:“你玩手机这事儿把老板惹毛了,说白了,你可以重新找工作了,等下&nbsp;HR&nbsp;会来跟你谈。”&nbsp;我当时脑子直接宕机,一句话都没憋出来。后面&nbsp;HR&nbsp;找我谈话,直属领导也在旁边。HR&nbsp;说我这毛病不是一次两次了,属于屡教不改,不光上班玩手机,还用公司电脑看论文、弄学校的事儿。我当时人都傻了,上班摸鱼是不对,可我都是闲得发慌的时候才摸啊!而且玩手机这事儿,从来没人跟我说过后果这么严重,更没人告诉我在公司学个习也算犯错!连一次口头提醒都没有,哪儿来的屡教不改啊?更让我膈应的是,昨天部门刚开了会,说四个实习生里留一个转正,让大家好好表现。结果今天我就因为玩手机被开了。但搞笑的是,开会前直属领导就把我叫去小会议室,明明白白告诉我:“转正这事儿你就别想了,你的学历达不到我们部门要求,当初招你进来也没打算给你这个机会。”合着我没入贵厂的眼是吧?可我都已经被排除在转正名单外了,摸个鱼至于直接把我开了吗?真的太离谱了!
rush$0522:转正名单没进,大概率本来就没打算留你
摸鱼被leader发现了...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务