LeetCode-043-字符串相乘
字符串相乘
题目描述:给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。
示例说明请见LeetCode官网。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/multiply-strings/
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解法一:数组遍历
- 首先,如果num1和num2有为0的,直接返回空字符串。
- 否则,声明一个list为temp用来记录每一行的乘积的结果;
- 然后将这些行的结果累加起来;
- 最后将累加的结果按倒序拼成字符串返回。
import java.util.ArrayList;
import java.util.List;
public class LeetCode_043 {
public static String multiply(String num1, String num2) {
if ((num1 == null || num1.length() == 0) || (num2 == null || num2.length() == 0)) {
return "";
}
if (num1.equals("0") || num2.equals("0")) {
return "0";
}
/**
* 如果num2的长度大于num1的长度将num1和num2的值交换
*/
if (num2.length() > num1.length()) {
String temp = num1;
num1 = num2;
num2 = temp;
}
/**
* 记录每一行的乘积的结果
*/
List<int[]> temp = new ArrayList<>();
int count = 0;
for (int i = num2.length() - 1; i >= 0; i--) {
int c2Num = num2.charAt(i) - '0';
int[] cur = new int[num1.length() + num2.length()];
int index = 0;
for (; index < count; index++) {
cur[index] = 0;
}
int addOne = 0;
for (int j = num1.length() - 1; j >= 0; j--) {
int c1Num = num1.charAt(j) - '0';
if (c2Num * c1Num + addOne > 9) {
cur[index++] = (c2Num * c1Num + addOne) % 10;
addOne = (c2Num * c1Num + addOne) / 10;
} else {
cur[index++] = c2Num * c1Num + addOne;
addOne = 0;
}
}
if (addOne > 0) {
cur[index] = addOne;
}
temp.add(cur);
count++;
}
int addOne = 0;
List<Integer> result = new ArrayList<>();
/**
* 将每一行的乘积结果累加起来
*/
for (int i = 0; i < num1.length() + num2.length(); i++) {
int curNum = addOne;
for (int[] ints : temp) {
curNum += ints[i];
}
if (curNum > 9) {
result.add(curNum % 10);
addOne = curNum / 10;
} else {
result.add(curNum % 10);
addOne = 0;
}
}
String resultStr = "";
int firstNoneZeroIndex = -1;
/**
* 找到第一个不为0的数字
*/
for (int i = result.size() - 1; i >= 0; i--) {
if (result.get(i) != 0) {
firstNoneZeroIndex = i;
break;
}
}
/**
* 将最后的结果拼成string并最后返回
*/
for (int i = firstNoneZeroIndex; i >= 0; i--) {
resultStr += String.valueOf(result.get(i));
}
return resultStr;
}
public static void main(String[] args) {
// 测试用例,预计输出: 56088
System.out.println(multiply("123", "456"));
}
}
【每日寄语】 再长的路,一步步也能走完,再短的路,不迈开双脚也无法到达。
LeetCode-043-字符串相乘的更多相关文章
- LeetCode 43. 字符串相乘(Multiply Strings)
43. 字符串相乘 43. Multiply Strings 题目描述 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. ...
- Java实现 LeetCode 43 字符串相乘
43. 字符串相乘 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 示例 1: 输入: num1 = "2& ...
- LeetCode 43 字符串相乘
题目: 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 示例 1: 输入: num1 = "2", ...
- LeetCode 43. 字符串相乘(Multiply Strings) 大数乘法
题目描述 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 示例 1: 输入: num1 = "2" ...
- [LeetCode]415. 字符串相加、43. 字符串相乘
题目 415. 字符串相加 给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和. 题解 维护一个temp表示当前两数相加+上一个进位的和. 每次更新结果的一位. 注意终止条件. 最后将 ...
- Leetcode中字符串总结
本文是个人对LeetCode中字符串类型题目的总结,纯属个人感悟,若有不妥的地方,欢迎指出. 一.有关数字 1.数转换 题Interger to roman和Roman to integer这两题是罗 ...
- 代码题(59)— 字符串相加、字符串相乘、打印最大n位数
1.415. 字符串相加 给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和. 思路:和链表相加类似,求进位. class Solution { public: string addS ...
- LeetCode:字符串的排列【567】
LeetCode:字符串的排列[567] 题目描述 给定两个字符串 s1 和 s2,写一个函数来判断 s2 是否包含 s1 的排列. 换句话说,第一个字符串的排列之一是第二个字符串的子串. 示例1: ...
- 前端与算法 leetcode 8. 字符串转换整数 (atoi)
目录 # 前端与算法 leetcode 8. 字符串转换整数 (atoi) 题目描述 概要 提示 解析 解法一:正则 解法二:api 解法二:手搓一个api 算法 传入测试用例的运行结果 执行结果 G ...
- 前端与算法 leetcode 387. 字符串中的第一个唯一字符
目录 # 前端与算法 leetcode 387. 字符串中的第一个唯一字符 题目描述 概要 提示 解析 解法一:双循环 解法二:Set法单循环 算法 传入测试用例的运行结果 执行结果 GitHub仓库 ...
随机推荐
- python3调用js的库之execjs
执行JS的类库:execjs,PyV8,selenium,node execjs是一个比较好用且容易上手的类库(支持py2,与py3),支持 JS runtime. 1.安装: pip install ...
- Shiro 简单介绍和快速入门。
一.shiro是啥? /* * Shiro ? 安全框架是一个 1.功能强大且易于使用的Java安全框架,可执行身份验证,授权,加密和会话管理,并可用于保护任何应用程序 - 从命令行应用程序,移动应用 ...
- 社交网络分析的 R 基础:(三)向量、矩阵与列表
在第二章介绍了 R 语言中的基本数据类型,本章会将其组装起来,构成特殊的数据结构,即向量.矩阵与列表.这些数据结构在社交网络分析中极其重要,本质上对图的分析,就是对邻接矩阵的分析,而矩阵又是由若干个向 ...
- iconv(gb2312<->utf-8)
转载请注明来源:https://www.cnblogs.com/hookjc/ unix下安装PHP的module,需要重新编译PHP,Windows下安装模板,只需将php.ini里的配置打开相应的 ...
- Android 三种菜单(Menu)的实现
感谢大佬:https://blog.csdn.net/chileme/article/details/82944764 一.常用方法 java onCreateOptionsMenu(Menu men ...
- memcache启动多个服务
windows 7 64bit 环境下安装memcached 1.下载后解压到D:\memcached(下载地址:memcached-win64下载地址) 2.安装到windows服务,打开cmd命令 ...
- 何为VRRP
VRRP 1.VRRP概述 2.VRRP结构 3.VRRP双主双备 前言:如何让多个网关能协同工作但又不会互相冲突?这时VRRP就应运而生,它可以实现网关的备份,又能解决多个网关之间互相冲突的问题. ...
- Maven获取resources的文件路径、读取resources的文件
路径问题一切要看编译后的文件路径 比如,源文件路径是: 而编译后的文件路径为: 也就是说,resources文件夹下的文件在编译后,都是为根目录,这种情况下,比如我要读取resources 文件夹下的 ...
- Java面试-常见基础笔试题目
1. Vector, ArrayList, LinkedList的区别 Vector:①长度可变,以类似数组的形式存储于内存中,线程安全(同步),因为其大部分方法都有synchronized 关键字, ...
- Dubbo SPI机制之三Adaptive自适应功能
JDK标准中SPI机制的一个问题就是其一次性实例化扩展点所有实现,如果有扩展实现初始化很耗时,但如果没用上也加载,会很浪费资源:扩展点加载失败,其他扩展点都用不了了.Dubbo是如何解决该问题动态的选 ...