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;
}
}