LeetCode

纵然是瞬间 提交于 2021-02-09 09:05:35

43. 字符串相乘

<div html="<p>给定两个以字符串形式表示的非负整数&amp;nbsp;<code>num1</code>&amp;nbsp;和&amp;nbsp;<code>num2</code>,返回&amp;nbsp;<code>num1</code>&amp;nbsp;和&amp;nbsp;<code>num2</code>&amp;nbsp;的乘积,它们的乘积也表示为字符串形式。</p>

<p><strong>示例 1:</strong></p>

<pre><strong>输入:</strong> num1 = &amp;quot;2&amp;quot;, num2 = &amp;quot;3&amp;quot; <strong>输出:</strong> &amp;quot;6&amp;quot;</pre>

<p><strong>示例&amp;nbsp;2:</strong></p>

<pre><strong>输入:</strong> num1 = &amp;quot;123&amp;quot;, num2 = &amp;quot;456&amp;quot; <strong>输出:</strong> &amp;quot;56088&amp;quot;</pre>

<p><strong>说明:</strong></p>

<ol> <li><code>num1</code>&amp;nbsp;和&amp;nbsp;<code>num2</code>&amp;nbsp;的长度小于110。</li> <li><code>num1</code> 和&amp;nbsp;<code>num2</code> 只包含数字&amp;nbsp;<code>0-9</code>。</li> <li><code>num1</code> 和&amp;nbsp;<code>num2</code>&amp;nbsp;均不以零开头,除非是数字 0 本身。</li> <li><strong>不能使用任何标准库的大数类型(比如 BigInteger)</strong>或<strong>直接将输入转换为整数来处理</strong>。</li> </ol> " class="notranslate"><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 = "2", num2 = "3" <strong>输出:</strong> "6"</pre>

<p><strong>示例&nbsp;2:</strong></p>

<pre><strong>输入:</strong> num1 = "123", num2 = "456" <strong>输出:</strong> "56088"</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> </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>给定两个字符串形式的非负整数&amp;nbsp;<code>num1</code> 和<code>num2</code>&amp;nbsp;,计算它们的和。</p>

<p><strong>注意:</strong></p>

<ol> <li><code>num1</code> 和<code>num2</code>&amp;nbsp;的长度都小于 5100.</li> <li><code>num1</code> 和<code>num2</code> 都只包含数字&amp;nbsp;<code>0-9</code>.</li> <li><code>num1</code> 和<code>num2</code> 都不包含任何前导零。</li> <li><strong>你不能使用任何內建 BigInteger 库,&amp;nbsp;也不能直接将输入的字符串转换为整数形式。</strong></li> </ol> " class="notranslate"><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> </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

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!