zoukankan      html  css  js  c++  java
  • 【LeetCode】2.两数相加

    题目

    给出两个非空的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储一位数字。

    如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。

    您可以假设除了数字 0 之外,这两个数都不会以 0 开头。

    示例:

    输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
    输出:7 -> 0 -> 8
    原因:342 + 465 = 807

    解法

    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode(int x) : val(x), next(NULL) {}
     * };
     */
    class Solution {
    public:
        ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
            ListNode* pointer = new ListNode(0);
            ListNode* result = pointer;
            int x = 0;
            while(l1 != NULL || l2 != NULL || x != 0){
                pointer->val = (l1==NULL?0:l1->val) + (l2==NULL?0:l2->val) + x;
                x = pointer->val / 10;
                pointer->val = pointer->val % 10;
                l1 = l1==NULL?NULL:l1->next;
                l2 = l2==NULL?NULL:l2->next;
                if(l1 != NULL || l2 != NULL || x != 0) {
                    pointer->next = new ListNode(0);
                    pointer = pointer->next;
                }
            }
            pointer->next = NULL;
            return result;
        }
    };
  • 相关阅读:
    观察者模式
    工厂模式
    单例模式
    关于状态机
    关于memset的错误使用
    关于STL容器
    关于内存及其相关
    python学习手册:第十一章——赋值表达式及打印
    python学习手册:第九章——元组、文件及其他
    python学习手册:第七章——字符串
  • 原文地址:https://www.cnblogs.com/tiumo/p/12667475.html
Copyright © 2011-2022 走看看