notes/OJ notes/pages/Leetcode Reverse-Words-In-a-String.md

91 lines
1.5 KiB
Markdown
Raw Permalink Normal View History

2022-07-12 09:19:55 +08:00
# Leetcode Reverse-Words-In-a-String
#### 2022-07-12 09:10
> ##### Algorithms:
2022-09-03 15:41:36 +08:00
>
> #algorithm #two_pointers
>
2022-07-12 09:19:55 +08:00
> ##### Data structures:
2022-09-03 15:41:36 +08:00
>
> #DS #string
>
2022-07-12 09:19:55 +08:00
> ##### Difficulty:
2022-09-03 15:41:36 +08:00
>
2022-09-06 20:22:48 +08:00
> #coding_problem #difficulty_easy
2022-09-03 15:41:36 +08:00
>
2022-07-12 09:19:55 +08:00
> ##### Additional tags:
2022-09-03 15:41:36 +08:00
>
> #leetcode
>
2022-07-12 09:19:55 +08:00
> ##### Revisions:
2022-09-03 15:41:36 +08:00
>
2022-07-12 09:19:55 +08:00
> N/A
##### Related topics:
2022-09-03 15:41:36 +08:00
2022-07-12 09:19:55 +08:00
##### Links:
2022-09-03 15:41:36 +08:00
2022-07-12 09:19:55 +08:00
- [Link to problem](https://leetcode.com/problems/reverse-words-in-a-string-iii/)
2022-09-03 15:41:36 +08:00
---
2022-07-12 09:19:55 +08:00
### 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"
#### Constraints
2022-09-03 15:41:36 +08:00
- `1 <= s.length <= 5 * 104`
- `s` contains printable **ASCII** characters.
- `s` does not contain any leading or trailing spaces.
- There is **at least one** word in `s`.
- All the words in `s` are separated by a single space.
2022-07-12 09:19:55 +08:00
### Thoughts
> [!summary]
2022-09-03 15:41:36 +08:00
> This is a #two_pointers
2022-07-12 09:19:55 +08:00
very easy and intuitive.
### Solution
```cpp
class Solution {
void reverse(string &s, int l, int r) {
if (l >= r) {
return;
}
swap(s[l++], s[r--]);
reverse(s, l, r);
}
public:
string reverseWords(string s) {
int slow = 0, fast;
for (int i = 0; i < s.size(); i++) {
if (s[i] == ' ') {
fast = i - 1;
reverse(s, slow, fast);
slow = i + 1;
}
}
reverse(s, slow, s.size() - 1);
return s;
}
};
2022-09-03 15:41:36 +08:00
```