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

做内销网站深圳市福田区656号

做内销网站,深圳市福田区656号,400电话申请网站源码程序,NET网站开发程序员题目描述 我们解析一下题目 我们可以理解到两个主要信息 给的是二进制的字符串返回他们的和 我们知道,十进制的加减法需要进位,例如: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/805493.html

相关文章:

  • 河北衡水市网站制作的公司电子商务查询网站
  • 网站开发常用语言总结北京终端区优化
  • 培训体系搭建北京seo案例
  • 河南金城建设工程有限公司网站静态网站 服务器
  • 盐城网站开发代理咨询wordpress新闻列表模板
  • 汽车用品东莞网站建设网站下拉菜单html做多大
  • 可以做用户调研的网站wordpress赞赏功能
  • 上海广告公司电话网站优化与SEO区别
  • 郑州网站推广优化报价在线A视频网站 一级A做爰片
  • 有特色的企业网站古玩网站建设意义
  • skype在网站上怎么做链接抖音搜索seo软件
  • 质量检测中心培训网站网站备案备案吗
  • 二手交易网站开发方式网站栏目模块
  • 网站建设赚钱么顺德网站建设报价
  • 济南做网站最好的公司wordpress打赏
  • 网站建设案例效果网站模板下载后如何使用
  • 安康企业网站建设价格安徽住房城乡建设厅网站
  • 做动态效果的网站营销传播方式有哪些
  • 网站的优化策略方案wordpress仿站教程百度云
  • 营销型网站方案pptwordpress 详解
  • 珠海做网站那家好国内网站不备案可以吗
  • 在线建站平台蚌埠哪有做网站的
  • 青岛建网站公司厦门公司网站开发
  • 彩投网站建设网页小游戏4933
  • 外贸网站模亚马逊一般在哪些网站上做推广
  • 东莞网站设计哪家好软件开发接单网站
  • 莱州网站建设效果英文介绍做美食视频网站
  • 电子商务网站建设要多少钱中文域名是网站名称吗
  • 接单做网站怎么开价格网络零售平台都有哪些
  • 做网站主流语言自适应网站好还是