-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLeetCode_402.cpp
More file actions
79 lines (60 loc) · 1.56 KB
/
Copy pathLeetCode_402.cpp
File metadata and controls
79 lines (60 loc) · 1.56 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
// class Solution {
// public:
// string removeKdigits(string num, int k) {
// stack<char> st;
// for(int i = 0; i < num.size(); i++) {
// while(!st.empty() && k > 0 && st.top() > num[i]) {
// st.pop();
// k--;
// }
// st.push(num[i]);
// }
// // remove remaining k digits
// while(k > 0 && !st.empty()) {
// st.pop();
// k--;
// }
// string str = "";
// while(!st.empty()) {
// str += st.top();
// st.pop();
// }
// reverse(str.begin(), str.end());
// // remove leading zeros
// int i = 0;
// while(i < str.size() && str[i] == '0') {
// i++;
// }
// str = str.substr(i);
// // if empty
// if(str == "") {
// return "0";
// }
// return str;
// }
// };
class Solution {
public:
string removeKdigits(string num, int k) {
string ans;
for(char ch : num) {
while(!ans.empty() && k > 0 && ans.back() > ch) {
ans.pop_back();
k--;
}
ans.push_back(ch);
}
// remove remaining digits
while(k > 0 && !ans.empty()) {
ans.pop_back();
k--;
}
// remove leading zeros
int i = 0;
while(i < ans.size() && ans[i] == '0') {
i++;
}
ans = ans.substr(i);
return ans.empty() ? "0" : ans;
}
};