-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path42_jianzhi_reverseWord.cpp
56 lines (52 loc) · 1.61 KB
/
42_jianzhi_reverseWord.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
46
47
48
49
50
51
52
53
54
55
56
class Solution {
public:
string ReverseSentence(string str) {
ReverseWord(str, 0 ,str.size()-1);
int start = 0, end = 0;
while(start < str.size()){
if(str[start] == ' ')
{
start++;
end++;
}
else if(str[end] == ' ' || end == str.size()){
ReverseWord(str, start, end-1);
start = ++end;
}
else
end++;
}
return str;
}
void ReverseWord(string &str, int start, int end){
while(start < end){
char c = str[start];
str[start] = str[end];
str[end] = c;
start++;
end--;
}
}
};
无力吐槽你们的做法了,这种AC,你们觉得面试能过吗?这道题考的核心是应聘者是不是可以灵活利用字符串翻转。假设字符串abcdef,n=3,设X=abc,Y=def,所以字符串可以表示成XY,如题干,问如何求得YX。假设X的翻转为XT,XT=cba,同理YT=fed,那么YX=(XTYT)T,三次翻转后可得结果。
class Solution {
public:
string LeftRotateString(string str, int n) {
if(str.empty() || n == 0)
return str;
ReverseWord(str, 0, n-1);
ReverseWord(str, n, str.size()-1);
ReverseWord(str, 0, str.size()-1);
return str;
}
void ReverseWord(string &str, int start, int end){
while(start < end){
char c = str[start];
str[start] = str[end];
str[end] = c;
start++;
end--;
}
}
};