forked from black-shadows/LeetCode-Topicwise-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrearrange-spaces-between-words.cpp
45 lines (44 loc) · 1.43 KB
/
rearrange-spaces-between-words.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
// Time: O(n)
// Space: O(1)
// inplace solution
class Solution {
public:
string reorderSpaces(string text) {
// count spaces and words
int space_count = 0, word_count = 0;
for (int i = 0; i < size(text); ++i) {
if (text[i] == ' ') {
++space_count;
} else if (i == 0 || text[i - 1] == ' ') {
++word_count;
}
}
// rearrange the spaces to the right
int left = 0, curr = 0;
for (int i = 0; i < size(text); ++i) {
bool has_word = false;
while (i < size(text) && text[i] != ' ') {
swap(text[left++], text[i++]);
has_word = true;
}
if (has_word) {
++left; // keep one space
}
}
// rearrange the spaces to the left
int equal_count = word_count - 1 > 0 ? space_count / (word_count - 1) : 0;
int extra_count = word_count - 1 > 0 ? space_count % (word_count - 1) : space_count;
int right = size(text) - 1 - extra_count;
for (int i = size(text) - 1; i >= 0; --i) {
bool has_word = false;
while (i >= 0 && text[i] != ' ') {
swap(text[right--], text[i--]);
has_word = true;
}
if (has_word) {
right -= equal_count; // keep equal_count spaces
}
}
return text;
}
};