LeetCode-Reverse Words in a String
Problem:
Given an input string, reverse the string word by word.
For example,
Given s = “the sky is blue”,
return “blue is sky the”.
For C programmers: Try to solve it in-place in O(1) space.
1 | public class Solution { |
thr runtime is 384ms
本来想说用二次字符串翻转来做的,比如第一次先以空格分隔翻转:eht yks si eulb
,然后再一次进行全部翻转之后即可得到blue is sky the
,但是代码提交到LeetCode之后他的Test Case中有去空格的Demo,老是Wrong,想想大致能用二次翻转完成就好,就没有继续调试了0-_-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
30public String reverseWords2(String s) {
byte[] bs=s.getBytes();
int length=bs.length;
int start=0,end=0;
for(int i=0;i<=length;i++)
{
if(i==length || bs[i]==32)
{
end=i-1;
reverse(bs,start,end);
start=i+1;
}
}
reverse(bs,0,length-1);
return new String(bs);
}
private void reverse(byte[] bs,int i,int j)
{
for(;i<j;i++,j--)
{
byte b=bs[i];
bs[i]=bs[j];
bs[j]=b;
}
}
JUnit Test Code1
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
39List<TestExample> testExampleList=new ArrayList<TestExample>();
@Before
public void before()
{
this.testExampleList.add(new TestExample(" a b ","b a"));//这个会失败 就没再测了
this.testExampleList.add(new TestExample("LeetCode","LeetCode"));
this.testExampleList.add(new TestExample("Hello World","World Hello"));
this.testExampleList.add(new TestExample("the sky is blue","blue is sky the"));
}
@Test
public void test()
{
ReverseWordsinaString reverse=new ReverseWordsinaString();
for(TestExample example:this.testExampleList)
{
Assert.assertEquals(reverse.reverseWords2(example.sourceStr),example.reverseStr);
}
}
@After
public void after()
{
this.testExampleList.clear();
}
static class TestExample{
public String sourceStr;
public String reverseStr;
public TestExample(String sourceStr,String reverseStr)
{
this.sourceStr=sourceStr;
this.reverseStr=reverseStr;
}
}
本作品采用[知识共享署名-非商业性使用-相同方式共享 2.5]中国大陆许可协议进行许可,我的博客欢迎复制共享,但在同时,希望保留我的署名权kubiCode,并且,不得用于商业用途。如您有任何疑问或者授权方面的协商,请给我留言。