-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy path043. Multiply Strings.cpp
55 lines (54 loc) · 1.74 KB
/
043. Multiply Strings.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
// Solution 1.
class Solution {
public:
string multiply(string num1, string num2) {
if(num1 == "0" || num2 == "0") return "0";
string res = "";
for(int i = num2.size() - 1, zero = 0; i >= 0; i--, zero++)
res=addStr(res, multiStr(num1, num2[i] - '0', zero));
return res;
}
//string * multiple -> string
string multiStr(string s, int multiple, int zero){
int carry = 0;
int n = 0;
for(int i = s.size()-1; i >= 0; i--){
n = (s[i]-'0') * multiple + carry;
s[i] = n%10 + '0';
carry = n/10;
}
if(carry) s = to_string(carry) + s;
while(zero) s += "0", zero--;
return s;
}
//string + string -> string
string addStr(string num1, string num2) {
string s = "";
int carry = 0;
for(int i = num1.size()-1, j = num2.size()-1; i >= 0 || j >= 0 || carry; i--, j--){
int x = i < 0 ? 0 : num1[i] - '0';
int y = j < 0 ? 0 : num2[j] - '0';
s.push_back((x + y + carry) % 10 + '0');
carry = (x + y + carry) / 10;
}
reverse(s.begin(), s.end());
return s;
}
};
// Solution 2.
class Solution {
public:
string multiply(string num1, string num2) {
vector<int>pos(num1.size() + num2.size());
for(int i = num1.size() - 1; i >= 0; i--){
for(int j = num2.size() - 1; j >= 0; j--){
int sum = (num1[i] - '0') * (num2[j] - '0') + pos[i + j + 1];
pos[i + j + 1] = sum % 10;
pos[i + j] += sum / 10;
}
}
string res = "";
for(auto x: pos) if(!(res == "" && x == 0)) res.push_back(x + '0');
return res == "" ? "0" : res;
}
};