43. Multiply Strings

  1. 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 num1 and num2 is < 110.
Both num1 and num2 contain only digits 0-9.
Both num1 and num2 do 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.
java

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;
                int p2 = i+j+1;
                int sum =mul + pos[p2];
                pos[p1] += sum/10;
                pos[p2] = sum%10;
            }
        }
        StringBuilder sb = new StringBuilder();
        for(int i:pos)
            if(!(sb.length()==0&& i ==0))
                sb.append(i);
        return sb.length()==0?"0":sb.toString();
    }
}

tips:

String对象是不可改变的。每次使用
System.String类中的方法之一时,都要在内存中创建一个新的字符串对象,这就需要为该新对象分配新的空间。在需要对字符串执行重复修改的情况下,与创建新的
String对象相关的系统开销可能会非常昂贵。如果要修改字符串而不创建新的对象,则可以使用System.Text.StringBuilder类。例如,当在一个循环中将许多字符串连接在一起时,使用
StringBuilder类可以提升性能。
通过用一个重载的构造函数方法初始化变量,可以创建 StringBuilder类的新实例,正如以下示例中所阐释的那样。

StringBuilder MyStringBuilder = new StringBuilder(“Hello World!”);

(一)设置容量和长度   
虽然StringBuilder对象是动态对象,允许扩充它所封装的字符串中字符的数量,但是您可以为它可容纳的最大字符数指定一个值。此值称为该对象的容量,不应将它与当前
StringBuilder对象容纳的字符串长度混淆在一起。例如,可以创建 StringBuilder类的带有字符串“Hello”(长度为
5)的一个新实例,同时可以指定该对象的最大容量为 25。当修改
StringBuilder时,在达到容量之前,它不会为其自己重新分配空间。当达到容量时,将自动分配新的空间且容量翻倍。可以使用重载的构造函数之一来指定
StringBuilder类的容量。以下代码示例指定可以将 MyStringBuilder对象扩充到最大 25个空白。
StringBuilderMyStringBuilder = new StringBuilder(“Hello World!”, 25);
另外,可以使用读/写 Capacity属性来设置对象的最大长度。以下代码示例使用 Capacity属性来定义对象的最大长度。
MyStringBuilder.Capacity= 25;

(二)下面列出了此类的几个常用方法: (1)Append 方法可用来将文本或对象的字符串表示形式添加到由当前
StringBuilder对象表示的字符串的结尾处。以下示例将一个 StringBuilder对象初始化为“Hello
World”,然后将一些文本追加到该对象的结尾处。将根据需要自动分配空间。 StringBuilderMyStringBuilder =
new StringBuilder(“Hello World!”); MyStringBuilder.Append(" What a
beautiful day."); Console.WriteLine(MyStringBuilder); 此示例将 Hello
World! What abeautiful day.显示到控制台。

(2)AppendFormat 方法将文本添加到 StringBuilder的结尾处,而且实现了
IFormattable接口,因此可接受格式化部分中描述的标准格式字符串。可以使用此方法来自定义变量的格式并将这些值追加到
StringBuilder的后面。以下示例使用 AppendFormat方法将一个设置为货币值格式的整数值放置到
StringBuilder的结尾。 int MyInt= 25; StringBuilder MyStringBuilder = new
StringBuilder("Your total is “); MyStringBuilder.AppendFormat(”{0:C}
", MyInt); Console.WriteLine(MyStringBuilder); 此示例将 Your total is
$25.00显示到控制台。

(3)Insert 方法将字符串或对象添加到当前 StringBuilder中的指定位置。以下示例使用此方法将一个单词插入到
StringBuilder的第六个位置。 StringBuilderMyStringBuilder = new
StringBuilder(“Hello World!”); MyStringBuilder.Insert(6,"Beautiful ");
Console.WriteLine(MyStringBuilder); 此示例将 Hello BeautifulWorld!显示到控制台。

(4)可以使用 Remove方法从当前 StringBuilder中移除指定数量的字符,移除过程从指定的从零开始的索引处开始。以下示例使用
Remove方法缩短 StringBuilder。 StringBuilderMyStringBuilder = new
StringBuilder(“Hello World!”); MyStringBuilder.Remove(5,7);
Console.WriteLine(MyStringBuilder); 此示例将 Hello显示到控制台。

(5)使用 Replace方法,可以用另一个指定的字符来替换 StringBuilder对象内的字符。以下示例使用 Replace方法来搜索
StringBuilder对象,查找所有的感叹号字符 (!),并用问号字符 (?)来替换它们。
StringBuilderMyStringBuilder = new StringBuilder(“Hello World!”);
MyStringBuilder.Replace(’!’, ‘?’); Console.WriteLine(MyStringBuilder);

python

class Solution:
    def multiply(self, num1: str, num2: str) -> str:
        n1= int(num1)
        n2 =int(num2)
        return str(n1*n2)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值