43. 字符串相乘
<div html="<p>给定两个以字符串形式表示的非负整数&nbsp;<code>num1</code>&nbsp;和&nbsp;<code>num2</code>,返回&nbsp;<code>num1</code>&nbsp;和&nbsp;<code>num2</code>&nbsp;的乘积,它们的乘积也表示为字符串形式。</p>
<p><strong>示例 1:</strong></p>
<pre><strong>输入:</strong> num1 = &quot;2&quot;, num2 = &quot;3&quot; <strong>输出:</strong> &quot;6&quot;</pre>
<p><strong>示例&nbsp;2:</strong></p>
<pre><strong>输入:</strong> num1 = &quot;123&quot;, num2 = &quot;456&quot; <strong>输出:</strong> &quot;56088&quot;</pre>
<p><strong>说明:</strong></p>
<ol> <li><code>num1</code>&nbsp;和&nbsp;<code>num2</code>&nbsp;的长度小于110。</li> <li><code>num1</code> 和&nbsp;<code>num2</code> 只包含数字&nbsp;<code>0-9</code>。</li> <li><code>num1</code> 和&nbsp;<code>num2</code>&nbsp;均不以零开头,除非是数字 0 本身。</li> <li><strong>不能使用任何标准库的大数类型(比如 BigInteger)</strong>或<strong>直接将输入转换为整数来处理</strong>。</li> </ol> " class="notranslate"><p>给定两个以字符串形式表示的非负整数 <code>num1</code> 和 <code>num2</code>,返回 <code>num1</code> 和 <code>num2</code> 的乘积,它们的乘积也表示为字符串形式。</p>
<p><strong>示例 1:</strong></p>
<pre><strong>输入:</strong> num1 = "2", num2 = "3" <strong>输出:</strong> "6"</pre>
<p><strong>示例 2:</strong></p>
<pre><strong>输入:</strong> num1 = "123", num2 = "456" <strong>输出:</strong> "56088"</pre>
<p><strong>说明:</strong></p>
<ol> <li><code>num1</code> 和 <code>num2</code> 的长度小于110。</li> <li><code>num1</code> 和 <code>num2</code> 只包含数字 <code>0-9</code>。</li> <li><code>num1</code> 和 <code>num2</code> 均不以零开头,除非是数字 0 本身。</li> <li><strong>不能使用任何标准库的大数类型(比如 BigInteger)</strong>或<strong>直接将输入转换为整数来处理</strong>。</li> </ol> </div>
JAVA
public static String multiply(String num1, String num2) {
if (num1.equals("0") || num2.equals("0")){
return "0";
}
int len1 = num1.length();
int len2 = num2.length();
int [] sums = new int[len1 + len2];
for (int i = len1 - 1; i >= 0; i--) {
int n1 = num1.charAt(i) - 48;
for (int j = len2 - 1; j >= 0; j--) {
int n2 = num2.charAt(j) - 48;
sums[i + j] += n1 * n2;
if (sums[i + j] > 9 && (i + j) != 0){
sums[i + j - 1] += sums[i + j] / 10;
sums[i + j] = sums[i + j] % 10;
}
}
}
StringBuilder builder = new StringBuilder();
for (int i = 0; i < len1 + len2 - 1; i++){
builder.append(sums[i]);
}
return builder.toString();
}
415. 字符串相加
<div html="<p>给定两个字符串形式的非负整数&nbsp;<code>num1</code> 和<code>num2</code>&nbsp;,计算它们的和。</p>
<p><strong>注意:</strong></p>
<ol> <li><code>num1</code> 和<code>num2</code>&nbsp;的长度都小于 5100.</li> <li><code>num1</code> 和<code>num2</code> 都只包含数字&nbsp;<code>0-9</code>.</li> <li><code>num1</code> 和<code>num2</code> 都不包含任何前导零。</li> <li><strong>你不能使用任何內建 BigInteger 库,&nbsp;也不能直接将输入的字符串转换为整数形式。</strong></li> </ol> " class="notranslate"><p>给定两个字符串形式的非负整数 <code>num1</code> 和<code>num2</code> ,计算它们的和。</p>
<p><strong>注意:</strong></p>
<ol> <li><code>num1</code> 和<code>num2</code> 的长度都小于 5100.</li> <li><code>num1</code> 和<code>num2</code> 都只包含数字 <code>0-9</code>.</li> <li><code>num1</code> 和<code>num2</code> 都不包含任何前导零。</li> <li><strong>你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式。</strong></li> </ol> </div>
JAVA
public static String strSum(String num1, String num2){
int i = num1.length() - 1;
int j = num2.length() - 1;
StringBuilder builder = new StringBuilder();
int carry = 0;
while (i >= 0 || j >= 0) {
if (i >= 0) {
carry += num1.charAt(i) - '0';
}
if (j >= 0) {
carry += num2.charAt(j) - '0';
}
builder.append((char)(carry % 10 + '0'));
carry /= 10;
i--;
j--;
}
if (carry == 1) {
builder.append('1');
}
return builder.reverse().toString();
}
原文出处:https://www.cnblogs.com/asche/p/11493482.html
来源:oschina
链接:https://my.oschina.net/u/4406952/blog/3253532