题解 | #牛群的能量值#

牛群的能量值

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;
    }
}

全部评论

相关推荐

Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
白火同学:能。我当初应届沟通了1200,收简历50,面试10左右吧,加油投吧
投了多少份简历才上岸
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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