• PHP算法之两数相加


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

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

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

    示例:

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

    /**
     * Definition for a singly-linked list.
     * class ListNode {
     *     public $val = 0;
     *     public $next = null;
     *     function __construct($val) { $this->val = $val; }
     * }
     */
    class Solution {

        /**
         * @param ListNode $l1
         * @param ListNode $l2
         * @return ListNode
         */
        function addTwoNumbers($l1, $l2) {
            $tree = null;
            
            $add = 0;
        
            do {
                $value = $l1->val + $l2->val + $add;
                if ($value < 10) {
                    $add = 0;
                } else {
                    $value -= 10;
                    $add = 1;
                }
                
                $obj = new ListNode($value);
                
                if (is_null($tree)) {
                    $tree = $obj;
                } else {
                    $next->next = $obj;
                }
                $next = $obj;
                
                $l1 = $l1->next;
                $l2 = $l2->next;
                
            } while ($l1 || $l2 || $add);
            
            return $tree;     
        }
    }
  • 相关阅读:
    《安卓网络编程》之第五篇 WebView的使用
    《安卓网络编程》之第四篇 处理URL地址
    《安卓网络编程》之第三篇 使用Apache接口
    《安卓网络编程》之第二篇 java环境下网络通信的综合应用
    《安卓网络编程》之第一篇 java环境下模拟客户端、服务器端
    星辉odoo教程
    星辉odoo教程
    星辉odoo实施
    星辉信息odoo教程
    星辉科技教程-centos搭建wechaty机器人运行环境
  • 原文地址:https://www.cnblogs.com/corvus/p/11947175.html
Copyright © 2020-2023  润新知