码迷,mamicode.com
首页 > 其他好文 > 详细

557. Reverse Words in a String III

时间:2017-12-06 14:22:03      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:logic   sha   col   log   input   code   oct   ret   ext   

Given a string, you need to reverse the order of characters in each word within a sentence while still preserving whitespace and initial word order.

Example 1:
Input: "Let‘s take LeetCode contest"
Output: "s‘teL ekat edoCteeL tsetnoc"
Note: In the string, each word is separated by single space and there will not be any extra space in the string.

 

I just wanted to use the same logic as Reverse Words in a String II.

Step 1. Convert the string to char[] array
Step 2. Whenever I encounter a space ‘ ‘ , I call the reverse function ( just to keep the code clean )
Step 3. Repeat till the end!

Hope this helps! Thanks for voting :)

  

public String reverseWords(String s) 
{
    char[] s1 = s.toCharArray();
    int i = 0;
    for(int j = 0; j < s1.length; j++)
    {
        if(s1[j] == ‘ ‘)
        {
            reverse(s1, i, j - 1);
            i = j + 1;
        }
    }
    reverse(s1, i, s1.length - 1);
    return new String(s1);
}

public void reverse(char[] s, int l, int r)
{
	while(l < r)
	{
		char temp = s[l];
		s[l] = s[r];
		s[r] = temp;
		l++; r--;
	}
}

  

557. Reverse Words in a String III

标签:logic   sha   col   log   input   code   oct   ret   ext   

原文地址:http://www.cnblogs.com/apanda009/p/7992084.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!