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

进一步加强网站内容建设阿里巴巴的网站怎么做

进一步加强网站内容建设,阿里巴巴的网站怎么做,wordpress自适应代码,免费网络在线打电话目录 ⼆进制求和(easy) 题目解析 讲解算法原理 编写代码 字符串相乘(medium) 题目解析 讲解算法原理 编写代码 ⼆进制求和(easy) 题目解析 1.题目链接:. - 力扣(LeetCode&a…

目录

⼆进制求和(easy)

题目解析

讲解算法原理

编写代码

字符串相乘(medium)

题目解析

讲解算法原理

编写代码


⼆进制求和(easy)

题目解析

1.题目链接:. - 力扣(LeetCode)

2.题目描述

给你两个⼆进制字符串 a 和 b ,以⼆进制字符串的形式返回它们的和。
⽰例 1:
输⼊:a = "11", b = "1"
输出:"100"
⽰例 2:
输⼊:a = "1010", b = "1011"
输出:"10101"

讲解算法原理

解法(模拟⼗进制的⼤数相加的过程):
算法思路:

模拟⼗进制中我们列竖式计算两个数之和的过程。但是这⾥是⼆进制的求和,我们不是逢⼗进⼀,⽽是逢⼆进⼀。

编写代码

c++算法代码:

class Solution
{
public:string addBinary(string a, string b) {string ret;int cur1 = a.size() - 1, cur2 = b.size() - 1, t = 0;while(cur1 >= 0 || cur2 >= 0 || t){if(cur1 >= 0) t += a[cur1--] - '0';if(cur2 >= 0) t += b[cur2--] - '0';ret += t % 2 + '0';t /= 2;}reverse(ret.begin(), ret.end());return ret;}
};

java算法代码:

class Solution
{public String addBinary(String a, String b) {StringBuffer ret = new StringBuffer();int cur1 = a.length() - 1, cur2 = b.length() - 1, t = 0;while(cur1 >= 0 || cur2 >= 0 || t != 0){if(cur1 >= 0) t += a.charAt(cur1--) - '0';if(cur2 >= 0) t += b.charAt(cur2--) - '0';ret.append((char)('0' + (char)(t % 2)));t /= 2;}ret.reverse();return ret.toString();}
}

字符串相乘(medium)

题目解析

1.题目链接:. - 力扣(LeetCode)

2.题目描述

给定两个以字符串形式表⽰的⾮负整数num1和num2,返回num1和num2的乘积,它们的乘积也表⽰为字符串形式。
注意:不能使⽤任何内置的BigInteger库或直接将输⼊转换为整数。⽰例1:
输⼊:num1="2",num2="3"
输出:"6"
⽰例2:
输⼊:num1="123",num2="456"
输出:"56088"

讲解算法原理

解法(⽆进位相乘然后相加,最后处理进位):
算法思路:

整体思路就是模拟我们⼩学列竖式计算两个数相乘的过程。但是为了我们书写代码的⽅便性,我们选择⼀种优化版本的,就是在计算两数相乘的时候,先不考虑进位,等到所有结果计算完毕之后,再去考虑进位。如下图:

 

编写代码

C++算法代码:

class Solution
{
public:string multiply(string n1, string n2) {// 解法:⽆进位相乘后相加,然后处理进位int m = n1.size(), n = n2.size();reverse(n1.begin(), n1.end());reverse(n2.begin(), n2.end());vector<int> tmp(m + n - 1);// 1. ⽆进位相乘后相加for(int i = 0; i < m; i++)for(int j = 0; j < n; j++)tmp[i + j] += (n1[i] - '0') * (n2[j] - '0');// 2. 处理进位int cur = 0, t = 0;string ret;while(cur < m + n - 1 || t){if(cur < m + n - 1) t += tmp[cur++];ret += t % 10 + '0';t /= 10;}// 3. 处理前导零while(ret.size() > 1 && ret.back() == '0') ret.pop_back();reverse(ret.begin(), ret.end());return ret;}
};

java算法代码:

class Solution
{public String multiply(String num1, String num2) {int m = num1.length(), n = num2.length();char[] n1 = new StringBuffer(num1).reverse().toString().toCharArray();char[] n2 = new StringBuffer(num2).reverse().toString().toCharArray();int[] tmp = new int[m + n - 1];// 1. ⽆进位相乘后相加for(int i = 0; i < m; i++)for(int j = 0; j < n; j++)tmp[i + j] += (n1[i] - '0') * (n2[j] - '0');// 2. 处理进位int cur = 0, t = 0;StringBuffer ret = new StringBuffer();while(cur < m + n - 1 || t != 0){if(cur < m + n - 1) t += tmp[cur++];ret.append((char)(t % 10 + '0'));t /= 10;}// 3. 处理进位while(ret.length() > 1 && ret.charAt(ret.length() - 1) == '0') ret.deleteCharAt((ret.length() - 1));return ret.reverse().toString();}
}

http://www.yayakq.cn/news/818509/

相关文章:

  • 商城网站模板库怎么查看一个网站是哪家公司做的
  • wordpress文章上作者广州排名seo公司
  • 深圳坪地网站建设 自助建站 五合一建站平台百度竞价账户
  • 学做衣服的网站有哪些wordpress手机版主题无效
  • 做彩票网站需要什么条件app界面设计流程
  • 网站建设用哪种语言好重庆装修除渣费一般多少
  • 链接网站logo为什么网站要域名解析
  • 建设网站企业网上银行苏州专业做网站公司电话
  • 聚牛网站建设公司小企业网站建设哪家便宜
  • 搜启网站建设网站负责人幕布照片
  • wap网站还用吗app备案查询网站
  • 民宿客栈网站制作科技志愿信息平台
  • 开化网站建设代码需求网站
  • soho建网站 必须先注册公司吗logo设计公司汉狮怎么样
  • 做外贸没有网站需要注意什么条件专业的做网站
  • 建设工程施工安全网站城阳做网站找哪家
  • 珠海网站建设培训班廊坊关键词seo排名方案
  • 如何查网站pv公司网站开发项目外包方案
  • 影视网站建设中国手机网站建设公司
  • 可以用AI做网站上的图吗惠州论坛网站建设
  • 常州做网站建设精品电商网站建设
  • 广西商城网站建设海外推广服务
  • 建立网站第一步是什么手机门户网站源码
  • 有什么网站可以做深圳初二的试卷练习晋城 网站建设
  • 佛山高端网站开发公司58同城网站建设推广排名
  • 大学生网站建设开题报告网站开发与维护的岗位特点职责
  • 一个专门做恐怖片的网站wordpress定时器
  • 网站平台建设总结每一天做网站
  • 建设银行杭州招聘网站做网站详细步骤
  • 綦江中国建设银行官网站专业的家居行业网站制作