Leetcode 简单十六 二进制求和

二进制求和:

Leetcode 简单十六 二进制求和

PHP 32ms:

class Solution {

    /**
     * @param String $a
     * @param String $b
     * @return String
     */
    function addBinary($a, $b) {
        $str1 = strrev($a);
        $str2 = strrev($b);
        $sum = '';
        $carry = 0;
        for($i = 0;$i <= max(strlen($str1),strlen($str2));$i++){
            $sum[$i] = $str1[$i] + $str2[$i] + $carry;
            if($sum[$i] - 1 == 1){
                $sum[$i] = 0;
                $carry = 1;
            }elseif($sum[$i] - 1 == 2){
                $sum[$i] = 1;
                $carry = 1;
            }else{
                $carry = 0;
            }
        }
        $re = strrev($sum);
        return $re[0] == 0 ? substr($re,1):$re;
    }
}