题解 | #牛群的能量值# 模拟进位加法

牛群的能量值

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

知识点

链表 模拟

思路

链表形式的模拟进位的大整数加法, 维护一个进位值carry

由加法的进位我们可以知道下一次的carry值是由上一次的k除以10得到的, 当前位置的值是 k % 10

  • 当两个链表都没到达末尾, k值由上一次剩下的carry + l1->val + l2->val组成
  • l1到达末尾, l2没到达末尾, k值由上一次剩下的carry + l2->val组成
  • l2到达末尾, l1没到达末尾, k值由上一次剩下的carry + l1->val组成 (和上一条不会同时出现)
  • l1 l2均到达末尾, k值由carry组成
  • l1 l2 到达末尾, carry为0, 循环结束

时间复杂度

只遍历了链表若干次 O(n)

AC code (C++)

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param l1 ListNode类 
     * @param l2 ListNode类 
     * @return ListNode类
     */
    ListNode* addEnergyValues(ListNode* l1, ListNode* l2) {
        // 模拟进位加法
        auto dummy = new ListNode(0);
        auto p = dummy;
        int carry = 0;
        while (l1 and l2) {
            int k = l1->val + l2->val + carry;
            p->next = new ListNode(k % 10);
            p = p->next, l1 = l1->next, l2 = l2->next;
            carry = k / 10;
        }
        while (l1) {
            int k = l1->val + carry;
            p->next = new ListNode(k % 10);
            p = p->next, l1 = l1->next;
            carry = k / 10;
        }
        while (l2) {
            int k = l2->val + carry;
            p->next = new ListNode(k % 10);
            p = p->next, l2 = l2->next;
            carry = k / 10;
        }
        while (carry) {
            p->next = new ListNode(carry % 10);
            p = p->next;
            carry /= 10;
        }
        return dummy->next;
    }
};

全部评论

相关推荐

(黑话警告⚠️:hc=岗位数量, mt=导师, ld=直属领导, cr=代码审查)25年1月,我加入了字节某前端团队,并期望能在这里待到秋招并尝试转正。然而,就在上周,ld 找我1v1,告诉我,我的能力和团队预期不太匹配,并和我劝退。晴天霹雳吗?肯定是有的。那一刻,脑子里嗡嗡作响,各种情绪翻涌。但冷静下来想想,这几个月,自己在能掌控的范围内,确实有不少地方做得不尽如人意。所以,我想把这段不算成功的经历复盘一下,希望能给同样在努力转正的你提个醒,避开我踩过的坑。一、ld 的要求要注意刚进组时,ld就和我聊过转正的事。我当时发问:“咱们这儿有hc 吗?” ld没直接回答,只是说:“看能力,能力到了...
牛客上的彭于晏:过来人告诉你,入职后要做的第一件事儿不是说主动找活儿做,你要先学会融入团队,摸清ld的性格,投其所好。然后才是展示你的能力,能力上可以说技术或者业务,以业务能力为主,技术能力为辅。优先保证自己对业务需求的开发保证质量效率,然后再谈技术的问题,不要你觉得啥啥啥不行就想着整体优化了(发现校招生最喜欢干这事儿),我工作快5年了发现搞这种的最后都没啥好的结果,产出没有还引入新的bug,校招或者实习的水平看到的问题别人看不到嘛?为什么别人不去搞?浪费时间还没收益的事儿不要去做,技术上的能力体现在对于一个新需求,在不符合现在业务发展的架构设计上,你能拿出好的技术方案同时能考虑到后续业务发展逐渐将技术架构引入合理的架构,这是一个漫长的过程而不是一次性的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务