php字符串相加的方法

问题

给定两个字符串形式的非负整数num1和num2 ,计算它们的和。

提示

num1和num2的长度都小于5100num1和num2都只包含数字0-9num1和num2都不包含任何前导零。

你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式

解题思路

一位一位的相加,余数累连,判断最后为 0 了,不再循环。

实例

class Solution {
 
    /**
 
    * @param String $num1
 
    * @param String $num2
 
    * @return String
 
    */
 
    function addStrings($num1, $num2) {
 
        $cur = 0;
 
        $i = strlen($num1) - 1;
 
        $j = strlen($num2) - 1;
 
        $str = '';
 
        $carry = 0;
 
        while ($i >= 0 || $j >= 0 || $carry) {
 
            $cur = $carry;
 
            if ($i >= 0) {
 
                $cur += $num1[$i--];
 
            }
 
            if ($j >= 0) {
 
                $cur += $num2[$j--];
 
            }
 
            $carry = floor($cur / 10);   // 向下取整,最后一次 0 的情况就不再循环
 
            $str = $cur % 10 . $str;     // 累连求余之后的结果, .$str 的操作可以避免反转结果
 
        }
 
        return $str;
 
    }}

php回溯算法计算组合总和的方法:给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。candidates 中的每个数字在每个组合中只能使用一次。说明:所 ...