首页 > 其他 > 详细

Reverse Words in a String II

时间:2015-02-06 16:34:09      阅读:239      评论:0      收藏:0      [点我收藏+]

Given an input string, reverse the string word by word. A word is defined as a sequence of non-space characters.

The input string does not contain leading or trailing spaces and the words are always separated by a single space.

For example,
Given s = "the sky is blue",
return "blue is sky the".

Could you do it in-place without allocating extra space?

 

先把每个词反转一遍, 再把整个string 反转一遍。

 1 public class Solution {
 2     public void reverseWords(char[] s) {
 3         for(int i = 0, j = 0; j <= s.length && i < s.length; j ++){
 4             if(j == s.length || s[j] == ‘ ‘){
 5                 reverse(s, i, j - 1);
 6                 i = j + 1;
 7             }
 8         }
 9         reverse(s, 0, s.length - 1);
10     }
11     
12     private void reverse(char[] c, int s, int e){
13         while(s < e){
14             char tmp = c[s];
15             c[s] = c[e];
16             c[e] = tmp;
17             s ++; e --;
18         }
19     }
20 }

 

Reverse Words in a String II

原文:http://www.cnblogs.com/reynold-lei/p/4277374.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!