Reverse Words in a String 3
Problem
Given a string s
, reverse the order of characters in each word within a sentence while still preserving whitespace and initial word order.
Examples
Example 1:
Input:
s = "Let's take Leetcode contest"
Output:
"s'teL ekat edoCteeL tsetnoc"
Example 2:
Input:
s = "God Ding"
Output:
"doG gniD"
Solution
Method 1 - Form the words in reverse order and append
Code
Java
public String reverseWords(String s) {
final StringBuilder result = new StringBuilder();
final StringBuilder word = new StringBuilder();
for (int i = 0; i < s.length(); i++) {
if (s.charAt(i) != ' ') {
word.insert(0, s.charAt(i)); // no need to reverse
} else {
result.append(word);
result.append(" ");
word.setLength(0);
}
}
// last word
result.append(word);
return result.toString();
}
Complexity
- ⏰ Time complexity:
O(n)
- 🧺 Space complexity:
O(n)
Method 2 - Use string reverse
public class Solution {
public String reverseWords(String s) {
char[] a = s.toCharArray();
for (int i = 0; i < a.length; i++) {
if (a[i] != ' ') {
int j = i;
while (j + 1 < a.length && a[j + 1] != ' ') {
j++; // move j to the end of the word
}
reverse(a, i, j);
i = j;
}
}
return new String(ca);
}
private void reverse(char[] a, int i, int j) {
for (; i < j; i++, j--) {
char tmp = ca[i];
a[i] = ca[j];
a[j] = tmp;
}
}
}
Complexity
- ⏰ Time complexity:
O(n)
- 🧺 Space complexity:
O(1)