当前位置: 首页 > wzjs >正文

邯郸有学做搭建网站的吗徐州app制作

邯郸有学做搭建网站的吗,徐州app制作,长沙网站seo收费,济南高新网站建设题目描述 我们解析一下题目 我们可以理解到两个主要信息 给的是二进制的字符串返回他们的和 我们知道,十进制的加减法需要进位,例如:9716是因为91之后进了一位,二进制也是如此,只不过十进制是逢10进1,二…

题目描述

在这里插入图片描述

我们解析一下题目

  • 我们可以理解到两个主要信息
    • 给的是二进制的字符串
    • 返回他们的和

我们知道,十进制的加减法需要进位,例如:9+7=16是因为9+1之后进了一位,二进制也是如此,只不过十进制是逢10进1,二进制是逢2进1.
但是我们这里还需要注意两点

  • 题目给的是字符串
  • 返回的和也是字符串

算法原理[[leetCode]]

先说结论

  • 核心打法:
    • 字符串转数字
      结果数字再转字符

因为按照我们的习惯,加法喜欢从后面往前开始依次加
所以我们这里定义一个循环
{

  • 把每个字符串的最后一个字符转成数字
  • 用sum变量记录他们的和
  • push他们的和%2+'0’到一个新的字符串里面
  • 用carry记录他们的进位
    }

这里的carry的值可能会出现三种情况

  • 和有3中情况
    - 0:%2还是0,直接写入
    - 1:%2还是1,小于2,直接写入
    - 2:%2是0,但是要进位,写入0之后,用carry值记录他们的进位1
  • 然后在循环中carry的值给到sum,一直带着进位,直到遇到能写入的位置
  • 因为我们是从后往前依次加,但是结果是要从前往后读取的,所以我们要把结果反转一下

代码

class Solution {public:string addBinary(string a, string b) {int i=a.size()-1;int j=b.size()-1;int carry=0;string result;while(i>=0||j>=0||carry>0){int sum=carry;if(i>=0){sum+=a[i]-'0';i--;}if(j>=0){sum+=b[j]-'0';j--;}result.push_back((sum%2)+'0');carry=sum/2;}reverse(result.begin(),result.end());return result;}};

在这里插入图片描述

时间复杂度:
在这里插入图片描述

http://www.dtcms.com/wzjs/798410.html

相关文章:

  • 河北衡水市网站制作的公司权威网站有哪些
  • 怎样做网站表白母版页和窗体做网站例子
  • 公司的网站设计制作北京 网站建设咨询顾问公司
  • 建设运营网站个人网站效果图咋做
  • 室内设计找工作网站深圳seo外包
  • er图关于网站建设金融理财管理网站源码 dedecms
  • 自己做网站语言构建服务器有没有99块钱做网站
  • 网站域名管理权限前几年做那个网站致富
  • 大型门户网站是这样炼成的源代码网站根目录文件
  • 网站开发课电商网站要素
  • 网站快速优化排名方法邢台旅游景点大全排名 免费
  • 食品行业网站建设婚纱网页制作
  • 大连网站建设价格低zzzcms建站系统
  • 网站建设 接单东莞连锁品牌设计制作
  • 从网上怎么做网站营销做网站带阿里云服务器多少钱
  • 网站建设行做写字楼的网站有哪些
  • 定制型网站开发wordpress搭建付费网站
  • 福田做棋牌网站建设哪家公司便宜营销型网站建设解决方案
  • 郑州专业做网站的网站做代码图像显示不出来
  • 记事本做网站怎么改字体中国域名后缀
  • 抖音关键词推广怎么做一个新的网站怎么做优化
  • 开不锈钢公司怎么做网站重庆建筑工程
  • 北京网站优化wyhseo灵感中心素材网站
  • 长沙开福区专业制作网站卖车网站
  • 南平抖音搜索排名seo软件seo关键词词库
  • 网站建设目标文档wordpress文章分页付费
  • 最短的网站湖北省电力建设三公司网站
  • 农业网站建设费用预算php自适应网站开发
  • 教育网站都有哪些网站开发 毕业答辩ppt
  • qt 可以做网站吗h5制作