43. Multiply Strings (大数乘法)
Given two non-negative integers num1 and num2 represented as strings, return the product of num1 and num2, also represented as a string.
Example 1:
Input: num1 = "2", num2 = "3"
Output: "6"
Example 2:
Input: num1 = "123", num2 = "456"
Output: "56088"
Note:
- The length of both num1andnum2is < 110.
- Both num1andnum2contain only digits0-9.
- Both num1andnum2do not contain any leading zero, except the number 0 itself.
- You must not use any built-in BigInteger library or convert the inputs to integer directly.
 class Solution {
     public String multiply(String num1, String num2) {
     int m = num1.length(), n = num2.length();
     int[] pos = new int[m + n];
     for(int i = m - 1; i >= 0; i--) {
         for(int j = n - 1; j >= 0; j--) {
             int mul = (num1.charAt(i) - '0') * (num2.charAt(j) - '0');
             int p1 = i + j, p2 = i + j + 1;
             int sum = mul + pos[p2];
             pos[p1] += sum / 10;
             pos[p2] = (sum) % 10;
         }
     }  
     StringBuilder sb = new StringBuilder();
     for(int p : pos)
         if(!(sb.length() == 0 && p == 0))
             sb.append(p);
     return sb.length() == 0 ? "0" : sb.toString();
     }
 }
43. Multiply Strings (大数乘法)的更多相关文章
- [leetcode]43. Multiply Strings高精度乘法
		Given two non-negative integers num1 and num2 represented as strings, return the product of num1 and ... 
- leetcode 43. Multiply Strings(高精度乘法)
		Given two numbers represented as strings, return multiplication of the numbers as a string. Note: Th ... 
- leetcode 43 Multiply Strings 大数相乘
		感觉是大数相乘算法里面最能够描述.模拟演算过程的思路 class Solution { public String multiply(String num1, String num2) { if(nu ... 
- [LeetCode] 43. Multiply Strings ☆☆☆(字符串相乘)
		转载:43. Multiply Strings 题目描述 就是两个数相乘,输出结果,只不过数字很大很大,都是用 String 存储的.也就是传说中的大数相乘. 解法一 我们就模仿我们在纸上做乘法的过程 ... 
- [Leetcode][Python]43: Multiply Strings
		# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 43: Multiply Stringshttps://leetcode.co ... 
- [LeetCode] 415 Add Strings && 67 Add Binary && 43 Multiply Strings
		这些题目是高精度加法和高精度乘法相关的,复习了一下就做了,没想到难住自己的是C++里面string的用法. 原题地址: 415 Add Strings:https://leetcode.com/pro ... 
- 【LeetCode】43. Multiply Strings 解题报告(Python & C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ... 
- 【LeetCode】43. Multiply Strings
		Multiply Strings Given two numbers represented as strings, return multiplication of the numbers as a ... 
- 43. Multiply Strings  字符串表示的大数乘法
		Given two numbers represented as strings, return multiplication of the numbers as a string. Note: Th ... 
随机推荐
- [development] __attribute__((weak))是干嘛的
			简单的说,就是当发生 “重复定义的时候”.被声明者会被冲突者覆盖掉. 这里还涉及了weak与alias连用的情况. 参见,里边有两个例子,很浅显易懂. https://my.oschina.net/s ... 
- LeetCode 976 Largest Perimeter Triangle 解题报告
			题目要求 Given an array A of positive lengths, return the largest perimeter of a triangle with non-zero ... 
- ECharts图形库
			ECharts图形库百度的项目,图形的创建也比较简单,直接引用Javascript即可 1,引入<script src="{{ url_for("static",f ... 
- 如何解决selenium打开chrome提示chromedriver.exe已停止工作
			场景:启动Chrome,打开URL,提示“disconnected: unable to connect to renderer” 解决方法:chromedriver与chrome的对应关系表, 需要 ... 
- 使用jquery.uploadify上传文件
			今天在网上找了一天,想要找到一个比较全的使用案例,结果发现基本上全是一个版本的... 我的问题主要是上传完成后,还需要将路径获取到,然后保存到数据库. 查了一下资料发现有这么一个参数onComplet ... 
- IE报错:[vuex] vuex requires a Promise polyfill in this browser.
			使用的是vue2.0版本 IE报错提醒: 导致原因:使用了 ES6 中用来传递异步消息的的Promise,而IE的浏览器不支持 解决办法: 1.安装babel-polyfill模块,babel-plo ... 
- java实现消息队列的两种方式
			https://blog.csdn.net/fenfenguai/article/details/79257928 
- 前端 HTML body标签相关内容 常用标签 表单标签 form里面的 label标签介绍
			定义:<label> 标签为 input 元素定义标注(标记). label标签功能:关联input标签文本与表达元素,点击input标签文本时,如同点击表单元素一样. label标签是行 ... 
- sql语句优化(二)
			1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 建立索引好处 : 之前做的一个项目 , 一个查询10w多条的数据 ,需要20s ,后来加 ... 
- MySQL 5.7 的SSL加密方法
			MySQL 5.7 的SSL加密方法 MySQL 5.7.6或以上版本 (1)创建证书开启SSL验证--安装opensslyum install -y opensslopenssl versionOp ... 
