LeetCode OJ 2. Add Two Numbers
You are given two non-empty linked lists representing two non-negative integers. The digits are stored in reverse order and each of their nodes contain a single digit. Add the two numbers and return it as a linked list.
You may assume the two numbers do not contain any leading zero, except the number 0 itself.
Input: (2 -> 4 -> 3) + (5 -> 6 -> 4)
Output: 7 -> 0 -> 8
解答
寒假刷的第一题……
相当于是实现一个全加器阵列……大概是还没有走出数逻的阴影……
当然局部变量要记得初始化,将Carry变量赋值为0,这样链表头节点的相加就可以归入链表中一般节点的相加,将Ans赋值为NULL,为循环中链表的插入做准备,每一位都要加上前一位Carry的值并重新计算Carry,第一位的前一位Carry的值是0,最后一位相加也要重新计算Carry,并且如果两个链表长度不同,程序进行到后面只对一个链表进行计算时,每一位也要加上前一位Carry的值并重新计算Carry,因为可能存在9+999999的情况,其实这样的情况也就相当于是一个全加器单元的一个加数是0,并且最后一位相加结束后Carry不为0,则要再增加一位。
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) {
    struct ListNode *Ans, *TempNode, *TailNode;
    int Carry;
    Carry = ;
    Ans = TailNode = NULL;
    while(NULL != l1 && NULL != l2){
        TempNode = (struct ListNode*)malloc(sizeof(struct ListNode));
        TempNode->val = (Carry + l1->val + l2->val) % ;
        TempNode->next = NULL;
        Carry = (Carry + l1->val + l2->val) / ;
        if(NULL == Ans){
            Ans = TempNode;
            TailNode = TempNode;
        }
        else{
            TailNode->next = TempNode;
            TailNode = TailNode->next;
        }
        l1 = l1->next;
        l2 = l2->next;
    }
    while(NULL != l1){
        TempNode = (struct ListNode*)malloc(sizeof(struct ListNode));
        TempNode->val = (Carry + l1->val) % ;
        TempNode->next = NULL;
        Carry = (Carry + l1->val) / ;
        TailNode->next = TempNode;
        TailNode = TailNode->next;
        l1 = l1->next;
    }
    while(NULL != l2){
        TempNode = (struct ListNode*)malloc(sizeof(struct ListNode));
        TempNode->val = (Carry + l2->val) % ;
        TempNode->next = NULL;
        Carry = (Carry + l2->val) / ;
        TailNode->next = TempNode;
        TailNode = TailNode->next;
        l2 = l2->next;
    }
     != Carry){
        TempNode = (struct ListNode*)malloc(sizeof(struct ListNode));
        TempNode->val = Carry;
        TempNode->next = NULL;
        TailNode->next = TempNode;
    }
    return Ans;
}
LeetCode OJ 2. Add Two Numbers的更多相关文章
- 【LeetCode OJ】Add Two Numbers
		题目:You are given two linked lists representing two non-negative numbers. The digits are stored in re ... 
- LeetCode OJ:Add Two Numbers (相加链表之数)
		You are given two linked lists representing two non-negative numbers. The digits are stored in rever ... 
- leetcode 第二题Add Two Numbers  java
		链接:http://leetcode.com/onlinejudge Add Two Numbers You are given two linked lists representing two n ... 
- 【LeetCode】445. Add Two Numbers II 解题报告(Python & C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 先求和再构成列表 使用栈保存节点数字 类似题目 日期 ... 
- 《LeetBook》LeetCode题解(2):Add Two Numbers [M]
		我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ... 
- C# 写 LeetCode Medium #2 Add Two Numbers
		2. Add Two Numbers You are given two non-empty linked lists representing two non-negative integers. ... 
- LeetCode 第二题 Add Two Numbers 大整数加法 高精度加法 链表
		题意 You are given two non-empty linked lists representing two non-negative integers. The digits are s ... 
- leetcode@ [2/43] Add Two Numbers / Multiply Strings(大整数运算)
		https://leetcode.com/problems/multiply-strings/ Given two numbers represented as strings, return mul ... 
- 【一天一道leetcode】 #2 Add Two Numbers
		一天一道leetcode系列 (一)题目: You are given two linked lists representing two non-negative numbers. The digi ... 
随机推荐
- CVE-2017-12149漏洞利用
			CVE-2017-12149 JBOOS AS 6.X 反序列化漏洞利用 这次分析一下 CVE-2017-12149 ,漏洞已经爆出有几天了,今天就把这个漏洞看一下. ... 
- java 根据日期获取星期
			private String getWeek(String date) { String[] arr=date.split("-"); Calendar calendar = Ca ... 
- hive之权限问题AccessControlException Permission denied: user=root, access=WR
			问题描述:在集群上,用hive分析数据出现如下错误 FAILED: Execution Error, return code from org.apache.hadoop.hive.ql.exec.D ... 
- delphi 获取webbrowser的cookies给Idhttp用
			网上方法一:(可获取,但不完全) 引用mshtml; IHTMLDocument(wb1.Document).cooke; 网上方法二:(获取不到!) 引用winnet,使用InternetGetCo ... 
- 为什么使能RPS/RFS, 或者RSS/网卡多队列后,QPS反而下降?
			http://laoar.github.io/blog/2017/05/07/rps/ TL;DR RPS 即receive side steering,利用网卡的多队列特性,将每个核分别跟网卡的一个 ... 
- appium  java 在android7.0真机上测试程序时报错command failed shell "ps 'uiautomator'"的解决方式
			1.找到appium的安装目录下的adb.js文件,目录为:Appium\node_modules\appium\node_modules\appium-adb\lib 2.打开adb.js,找到如下 ... 
- pyautogui控制鼠标键盘自动填写数据
			import os import pyautogui import time, os import pyperclip # 复制 pyautogui.FAILSAFE = False class Au ... 
- 精通Web Analytics 2.0 (12) 第十章:针对潜在的网站分析陷阱的最佳解决方案
			精通Web Analytics 2.0 : 用户中心科学与在线统计艺术 第十章:针对潜在的网站分析陷阱的最佳解决方案 是时候去处理网站分析中最棘手的一些问题了,然后获得属于你的黑带,这是成为分析忍者的 ... 
- PHP Yii2.0PHPexecl导入。
			use app\models\execl; use \PHPExcel; /*execl导入数据*/ public function Execlupload(){ if(Yii::$app->r ... 
- 07.linux系统管理命令
			1.图形界面管理: 如想从图形界面切换至字符界面 输入 init 3 如想字符界面切换至图形界面 init 5 2.进程管理: kill 杀死一个进程 Kill -9 强制杀死一个进程 stat ... 
