题解 | #牛群的能量值#

牛群的能量值

https://www.nowcoder.com/practice/fc49a20f47ac431981ef17aee6bd7d15

知识点:

  1. 单链表的遍历与操作。
  2. 逆序表示的链表相加。

题意分析:

题目描述了两群牛的能量值,能量值用链表表示,每个节点的值为能量值的一位数字。能量值按照逆序的方式存储在链表中,即链表的第一个节点表示个位,第二个节点表示十位,以此类推。现在需要将这两个逆序链表的能量值相加,然后以相同的逆序形式返回表示和的链表。

时间复杂度:

假设两个链表分别有M和N个节点。

  1. 在代码中,我们需要遍历两个链表,进行逐位相加,并生成新的结果链表。在最坏情况下,需要遍历两个链表的所有节点,因此时间复杂度为O(max(M, N))。

代码分析:

代码中的解决思路是使用游标指针head1head2同时遍历两个链表,然后逐位相加。通过维护一个进位值carry,来处理相加后的进位情况。同时,使用一个新的链表newHead来保存相加的结果。最后,检查是否有进位值为1,若有,需要添加一个新的节点作为最高位。

代码:

import java.util.*;

class ListNode {
    int val;
    ListNode next;

    public ListNode(int val) {
        this.val = val;
    }
}

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param head1 ListNode类
     * @param head2 ListNode类
     * @return ListNode类
     */
    public ListNode addEnergyValues(ListNode head1, ListNode head2) {
        // 创建一个新的头节点,并用 cur 指针指向头节点
        ListNode newHead = new ListNode(-1);
        ListNode cur = newHead;
        int carry = 0; // 进位值初始化为0

        // 循环遍历两个链表,直到两个链表都为空
        while (head1 != null || head2 != null) {
            // 获取当前节点的值,如果节点为空则用0代替
            int val1 = head1 != null ? head1.val : 0;
            int val2 = head2 != null ? head2.val : 0;

            // 计算当前位置的和以及进位值
            int sum = val1 + val2 + carry;
            int digit = sum % 10;
            carry = sum / 10;

            // 创建一个新的节点,并将其添加到结果链表中
            cur.next = new ListNode(digit);
            cur = cur.next;

            // 移动指针到下一个节点
            if (head1 != null) head1 = head1.next;
            if (head2 != null) head2 = head2.next;
        }

        // 最后检查进位值是否为1,若为1则需要添加一个新的节点作为最高位
        if (carry == 1) {
            cur.next = new ListNode(1);
        }

        // 返回结果链表的头节点的下一个节点,即去除头节点的结果链表
        return newHead.next;
    }
}

全部评论

相关推荐

10-19 10:28
已编辑
西南石油大学 后端工程师
团孝子已上线feeling:面了很多家公司,能感受到目前只有小公司+外包喜欢问八股。大厂虽然也问八股,但是是从实习、项目中进行提问,并且大厂会问很深,面试官也会对你的回答进行思考➕追问,所以准备大厂面试前一定要备好相关资料。对于算法,我做的是codetop前100+力扣hot100+力扣高频150,面试中实感hot100就足够,基本上只要是hot100就秒答。对于项目和八股,我做的也是烂大街的星球项目,八股则是看小林和问ai,自己也写了很多技术博客和画了很多思维导图,并且自己也尝试用嘴巴说出来,不只停留于纸面。运气也很重要,必须要让面试官/HR看到简历才行,所以建议投递时间是下午两点。tl:第一岗位9.9 投递9.10 一面(一面评价:最近见过最强的大三,结束五分钟后约二面,都晚上九点了不下班吗)9.11 二面(三道算法a出两道,反问评价:经验不够等横向,我实习生要啥经验)9.21挂(实习时间过短+其他原因,想要一年实习的,为什么不招个正职)第二岗位10.10投递10.11约面(主管打电话,说看到我之前投递记录了想要我挂qa职进去干后端,同意)10.14 一面(无八股,主动说确实很强,意愿很强)10.16 oc其余,友邦,东软,东华,惠择,用友oc已拒京东测开一面挂(投后端被测开捞)腾讯测试已拒(投后端被测开捞)ps:表扬惠择的主管面,没怎么问技术(可能是一面面试官沟通过了),全程一起讲大道理,解答了心中很多疑惑,也告诉我以面试官角度来看怎么选候选人,如果可以下次一定选惠择
HeaoDng:美团好像可以触发一面通
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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