两数相加

思路:
1、定义一个临时变量,遍历两个链表,把当前节点的和保存在链表中。
2、定义一个临时变量保存进制数。
3、把相加的和取余数保存在新的链表中。
做题步骤:
1、拿到代码先判断链表是否为空
2、定义新的链表指向原始链表的表头,尽量不要破坏掉原始链表结构。
3、定义新链表用来存储相加信息。
4、循环遍历,相加,取余入链表。

ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    if(l1 == NULL || l2 == NULL)
        return NULL;
    int tempVar = 0;
    ListNode *list1 = l1, *list2 = l2;
    ListNode *newList = new ListNode(0); 
    ListNode *node = newList;
    while(list1 != NULL || list2 != NULL || tempVar != 0) {
        int data = 0;
        if(list1 != NULL) data += list1->val;
        if(list2 != NULL) data += list2->val;
        data += tempVar;
        tempVar = data / 10;
        data %= 10;
        ListNode *pCur = new ListNode(data);
        node->next = pCur;
        node = node->next;
        if(list1 != NULL) list1 = list1->next;
        if(list2 != NULL) list2 = list2->next;
    }
    return newList->next;
}

你可能感兴趣的:(leetcode)