Skip to content

Commit 8952c85

Browse files
authored
Create maximum-swap.cpp
1 parent a1c4dfa commit 8952c85

File tree

1 file changed

+21
-0
lines changed

1 file changed

+21
-0
lines changed

C++/maximum-swap.cpp

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
// Time: O(l), l is the length of the number string
2+
// Space: O(l)
3+
4+
class Solution {
5+
public:
6+
int maximumSwap(int num) {
7+
string digits = to_string(num);
8+
int left = 0, right = 0;
9+
int max_idx = digits.length() - 1;
10+
for (int i = digits.length() - 1; i >= 0; --i) {
11+
if (digits[i] > digits[max_idx]) {
12+
max_idx = i;
13+
} else if (digits[max_idx] > digits[i]) {
14+
left = i;
15+
right = max_idx;
16+
}
17+
}
18+
swap(digits[left], digits[right]);
19+
return stoi(digits);
20+
}
21+
};

0 commit comments

Comments
 (0)