LeetCode(43):字符串相乘

Medium!

题目描述:

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。

示例 1:

输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"
输出: "56088"

说明:

  1. num1 和 num2 的长度小于110。
  2. num1 和 num2 只包含数字 0-9
  3. num1 和 num2 均不以零开头,除非是数字 0 本身。
  4. 不能使用任何标准库的大数类型(比如 BigInteger)或直接将输入转换为整数来处理。

解题思路:

这道题让我们求两个字符串数字的相乘,输入的两个数和返回的数都是以字符串格式储存的,这样做的原因可能是这样可以计算超大数相乘,可以不受int或long的数值范围的约束,那么我们该如何来计算乘法呢,我们小时候都学过多位数的乘法过程,都是每位相乘然后错位相加,那么这里就是用到这种方法,参见http://www.cnblogs.com/TenosDoIt/p/3735309.html,把错位相加后的结果保存到一个一维数组中,然后分别每位上算进位,最后每个数字都变成一位,去除掉首位0,把每位上的数字按顺序保存到结果中即可。

我们以289*785为例:

C++解法一:

 1 class Solution {
 2 public:
 3     string multiply(string num1, string num2) {
 4         string res;
 5         int n1 = num1.size(), n2 = num2.size();
 6         int k = n1 + n2 - 2, carry = 0;
 7         vector<int> v(n1 + n2, 0);
 8         for (int i = 0; i < n1; ++i) {
 9             for (int j = 0; j < n2; ++j) {
10                 v[k - i - j] += (num1[i] - ‘0‘) * (num2[j] - ‘0‘);
11             }
12         }
13         for (int i = 0; i < n1 + n2; ++i) {
14             v[i] += carry;
15             carry = v[i] / 10;
16             v[i] %= 10;
17         }
18         int i = n1 + n2 - 1;
19         while (v[i] == 0) --i;
20         if (i < 0) return "0";
21         while (i >= 0) res.push_back(v[i--] + ‘0‘);
22         return res;
23     }
24 };

原文地址:https://www.cnblogs.com/ariel-dreamland/p/9139468.html

时间: 2024-10-25 22:45:37

LeetCode(43):字符串相乘的相关文章

LeetCode 43. 字符串相乘(Multiply Strings)

43. 字符串相乘 43. Multiply Strings 题目描述 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. LeetCode43. Multiply Strings中等 示例 1: 输入: num1 = "2", num2 = "3" 输出: "6" 示例?2: 输入: num1 = "123", num2 = "456&q

LeetCode 43. 字符串相乘(Multiply Strings) 大数乘法

题目描述 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 示例 1: 输入: num1 = "2", num2 = "3" 输出: "6" 示例 2: 输入: num1 = "123", num2 = "456" 输出: "56088" 说明: num1 和 num2 的长度小于110. num1 和 nu

43. 字符串相乘

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 示例 1: 输入: num1 = "2", num2 = "3" 输出: "6" 示例 2: 输入: num1 = "123", num2 = "456" 输出: "56088" 说明: num1 和 num2 的长度小于110. num1 和 num2 只包

leetcode 43 大数相乘

这题如果如果开挂的话, 可以直接用BigInteger类. 思路 用了三个辅助方法: 1. 大数相加.(顺带实现的,毕竟乘法的过程中需要用到加法) 2. 大数 * 一位数字 (很基础的步骤,列竖式的时候用到) 3. 去除结果的前导0.(很容易忽略,如0 * 123 结果会是 000,正确的结果应该是0) 然后就是利用这三个辅助方法得到最终结果.写法虽然直接但是有点繁琐,后续会考虑优化一下. 1 class Solution { 2 public String multiply(String nu

LeetCodr 43 字符串相乘

思路 用一个数组记录乘积的结果,最后处理进位. 代码 class Solution { public: string multiply(string num1, string num2) { if(num1 == "0" || num2 == "0") return "0"; reverse(num1.begin(), num1.end()); reverse(num2.begin(), num2.end()); int a[num1.lengt

Leetcode中字符串总结

本文是个人对LeetCode中字符串类型题目的总结,纯属个人感悟,若有不妥的地方,欢迎指出. 一.有关数字 1.数转换 题Interger to roman和Roman to integer这两题是罗马数字和整数之间的相互转换,首先要懂得什么是罗马数字以及相应的组数规则.LeetCode的题中给出的数字最大的是3999,.针对第一题有两种解法:第一是列举出罗马数字在个十百千上的各种情况,形成一个二维矩阵,然后对整数不停的取余.除10来确定相应的罗马数字:第二种是先列出罗马数字组成情况,然后通过从

LeetCode:字符串相加【415】

LeetCode:字符串相加[415] 题目描述 给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和. 注意: num1 和num2 的长度都小于 5100.num1 和num2 都只包含数字 0-9.num1 和num2 都不包含任何前导零.你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式. 题目分析 这道题其实很简单,我们要搞清楚手工计算两数之和的流程.两数相加,和如果大于10的话就有进位,进位最高为1,默认为0,该位相加的和应为sum%

前端与算法 leetcode 387. 字符串中的第一个唯一字符

目录 # 前端与算法 leetcode 387. 字符串中的第一个唯一字符 题目描述 概要 提示 解析 解法一:双循环 解法二:Set法单循环 算法 传入测试用例的运行结果 执行结果 GitHub仓库 查看更多 # 前端与算法 leetcode 387. 字符串中的第一个唯一字符 题目描述 给定一个字符串,找到它的第一个不重复的字符,并返回它的索引.如果不存在,则返回 -1. 案例: s = "leetcode" 返回 0. s = "loveleetcode",

[LeetCode] Multiply Strings 字符串相乘

Given two numbers represented as strings, return multiplication of the numbers as a string. Note: The numbers can be arbitrarily large and are non-negative. 这道题让我们求两个字符串数字的相乘,输入的两个数和返回的数都是以字符串格式储存的,这样做的原因可能是这样可以计算超大数相乘,可以不受int或long的数值范围的约束,那么我们该如何来计算