-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathaddString415.cpp
More file actions
106 lines (96 loc) · 2.36 KB
/
addString415.cpp
File metadata and controls
106 lines (96 loc) · 2.36 KB
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
class Solution {
public:
string addStrings(string num1, string num2) {
stack<int> s1;
stack<int> s2;
for (int i = 0; i < num1.size(); i++) {
s1.push(num1[i]-'0');
}
for (int i = 0; i < num2.size(); i++) {
s2.push(num2[i]-'0');
}
int carry = 0;
int sum = 0;
stack<int> s3;
while(!s1.empty() || !s2.empty())
{
int num1 = 0;
int num2 = 0;
sum = 0;
if(!s1.empty())
{
num1 = s1.top();
s1.pop();
}
if(!s2.empty())
{
num2 = s2.top();
s2.pop();
}
sum = num1 + num2 + carry;
if(sum >= 10)
{
carry = 1;
sum = sum%10;
}
else
{
carry = 0;
}
s3.push(sum);
}
if(carry != 0)
{
s3.push(carry);
}
string ans;
while(!s3.empty())
{
ans+=to_string(s3.top());
s3.pop();
}
return ans;
}
};
//the fatest method
class Solution {
public:
string
addStrings(string num1, string num2)
{
int difference = 0;
std::string longString = "";
std::string shortString = "";
if (num1.size()>=num2.size())
{
difference = num1.size()-num2.size();
longString = num1;
shortString.resize(difference, '0');
shortString = shortString + num2;
}
else
{
difference = num2.size()-num1.size();
longString = num2;
shortString.resize(difference, '0');
shortString = shortString + num1;
}
int carryOut = 0;
int i = longString.size()-1;
for (; i>=0; --i)
{
longString[i] = longString[i]+shortString[i]-48+carryOut;
if (longString[i]>=58)
{
carryOut = 1;
longString[i]-=10;
}
else carryOut = 0;
}
if (carryOut==1 && i<0)
{
longString = '1'+longString;
}
return longString;
}
};