问题描述

给定一个字符串,逐个翻转字符串中的每个单词。

说明:
无空格字符构成一个 单词 。
输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个

示例 1:
输入:“the sky is blue”
输出:“blue is sky the”
示例 2:
输入:" hello world! "
输出:“world! hello”
解释:输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
示例 3:
输入:“a good example”
输出:“example good a”
解释:如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。
示例 4:
输入:s = " Bob Loves Alice "
输出:“Alice Loves Bob”
示例 5:
输入:s = “Alice does not even like bob”
输出:“bob like even not does Alice”

提示:

1 <= s.length <= 104
s 包含英文大小写字母、数字和空格 ’ ’
s 中 至少存在一个 单词

分析思路

注意提示中加粗的部分,参数s前后可能有空格,要去掉前后的空格,单词与单词之间可能有多个空格,要减少到一个空格,所以判断当前字符数组中当前元素是不是空格,并且当前元素的前一个元素是不是空格,如果是连续的空格,只保留第一个空格,剩下的让不是空格的元素填充。最终得到一个合适的字符数组,计算出数组的有效长度。

接下来就是翻转单词的操作了,我们先把整个数组翻转一次,然后再将每个单词翻转一次,这样单词就成了我们想要的样子。翻转的方法就是两个指针,一个从左开始,一个从右开始,两者指向的元素进行交换,当两个指针碰头的时候交换结束。左右指针分别就是这个单词的下标区间的左区间和右区间。

单词翻转过后,还没有结束,因为我们规定单词语单词之间以空格分隔,但是最后一个单词的后面没有空格,需要对他进行额外的一次翻转,区间是[最后一个空格所在的下标+1,len);最终返回字符串,构造方法中传入的参数是字符数组,从0开始到len结束。

代码实现

具体每一步骤的解释都在注释中。

public String reverseWords(String s) {
if (s == null||s.equals("")){
return null;
}
//翻转字符串
char[] charArray = s.toCharArray();
//cur是慢指针,len代表有效长度(去掉两端的空格和连续的空格)
int cur=0,len = 0;
//space表示当前字符的前一个是不是空格,true是空格,false不是
boolean space = true;
//先求出有效长度并将字符数组中多余的空格去掉
for (int i = 0; i < charArray.length; i++) {
//如果当前字符不是空格
if(charArray[i]!=' '){
//将cur慢指针所指向的元素设置成当前元素
charArray[cur++] = charArray[i];
space = false;
}else if(space==false){
//如果当前是空格,并且当前元素的前一个元素不是空格,将cur指向的元素设置成空格
charArray[cur++] = charArray[i];
space=true;
}
}
//最终判断如果最后一个元素是空格,有效长度等于cur-1;否则等于cur
len = space?cur-1:cur;
//翻转字符串
reverseStr(charArray,0,len); //区间翻转字符串,preIndex=-1起哨兵的作用
int prevIndex = -1;
for (int i = 0; i < len; i++) {
//如果当前元素不是空格直接continue
if(charArray[i]!=' '){
continue;
}
//是空格就进行区间翻转也是将一个个单词翻转
reverseStr(charArray,prevIndex+1,i);
//每次修改区间开始的位置就是空格所在的下标 [preIndex,i)
prevIndex = i;
}
//翻转最后一个单词
reverseStr(charArray,prevIndex+1,len);
return new String(charArray,0,len);
}
//翻转指定区间内的字符数组
private void reverseStr(char[] array,int li,int ri){
ri--;
while(li<ri){
swap(array,li,ri);
li++;
ri--;
}
}
//交换两个元素
private void swap(char [] array,int i,int j){
char temp = array[i];
array[i] = array[j];
array[j] = temp;
}

写有用的文章,希望对大家有所帮助!

LeetCode-151-中等-翻转字符串里面的单词的更多相关文章

  1. C#版(击败100.00%的提交) - Leetcode 151. 翻转字符串里的单词 - 题解

    版权声明: 本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址 http://blog.csdn.net/lzuacm. C#版 - L ...

  2. [LeetCode] 151. Reverse Words in a String 翻转字符串中的单词

    Given an input string, reverse the string word by word. For example,Given s = "the sky is blue& ...

  3. LeetCode 151. 翻转字符串里的单词(Reverse Words in a String)

    151. 翻转字符串里的单词 151. Reverse Words in a String

  4. Java实现 LeetCode 151 翻转字符串里的单词

    151. 翻转字符串里的单词 给定一个字符串,逐个翻转字符串中的每个单词. 示例 1: 输入: "the sky is blue" 输出: "blue is sky th ...

  5. 【LeetCode】151. 翻转字符串里的单词(剑指offer 58-I)

    151. 翻转字符串里的单词 知识点:字符串:双指针 题目描述 给你一个字符串 s ,逐个翻转字符串中的所有 单词 . 单词 是由非空格字符组成的字符串.s 中使用至少一个空格将字符串中的 单词 分隔 ...

  6. 【LeetCode】151. Reverse Words in a String 翻转字符串里的单词(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.co ...

  7. [LeetCode] 186. Reverse Words in a String II 翻转字符串中的单词 II

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

  8. [LeetCode] 557. Reverse Words in a String III 翻转字符串中的单词 III

    Given a string, you need to reverse the order of characters in each word within a sentence while sti ...

  9. leetcode python翻转字符串里的单词

    # Leetcode 151 翻转字符串里的单词### 题目描述给定一个字符串,逐个翻转字符串中的每个单词. **示例1:** 输入: "the sky is blue" 输出: ...

  10. [LeetCode] Reverse Words in a String 翻转字符串中的单词

    Given an input string, reverse the string word by word. For example, Given s = "the sky is blue ...

随机推荐

  1. 如何建一个SAM

    部分改编自OI WIKI 先从一个简单的问题入手: 给定一个串,构造一个图,使其能够表示它的所有子串. 显然一个子串就是一个后缀的前缀.所以一个很显然的方式就是把所有后缀扔进trie里. 比如当前串是 ...

  2. 【题解】「P6771」[USACO05MAR]Space Elevator 太空电梯

    P6771 这是一道很明显的 dp 问题. 首先 dp 最重要的三要素是:动态表示.动态转移.初始状态. 只要这三个要素搞明白了,基本就能把这题做出来了. solution 让我们来看看这题的动态表示 ...

  3. css处理文字不换行、换行截断、溢出省略号

    1.使文字不换行 white-space: nowrap; 值 描述 normal 默认.空白会被浏览器忽略. pre 空白会被浏览器保留.其行为方式类似 HTML 中的 <pre> 标签 ...

  4. 主从复制直接转换MGR_5.7验证试验

    环境信息 IP port role info 192.168.188.51 4000 node1 master 192.168.188.52 4000 node2 slave1 192.168.188 ...

  5. 11g RAC 集群数据库不能跟随集群启动

    1.查看集群资源详细情况 [oracle@rac01-+ASM1 ~]$ crsctl stat res -p 2.修改集群资源ora.rac.db的auto_start属性改为always [ora ...

  6. 我是如何用go-zero 实现一个中台系统的

    最近发现golang社区里出了一个新星的微服务框架,来自好未来,光看这个名字,就很有奔头,之前,也只是玩过go-micro,其实真正的还没有在项目中运用过,只是觉得 微服务,grpc 这些很高大尚,还 ...

  7. css进阶 03-网页设计和开发中,关于字体的常识

    03-网页设计和开发中,关于字体的常识 #前言 我周围的码农当中,有很多是技术大神,却常常被字体这种简单的东西所困扰. 这篇文章,我们来讲一讲关于字体的常识.这些常识所涉及到的问题,有很强的可操作性, ...

  8. python监控文件实时批量压缩脚本

    # coding:utf-8 from shutil import make_archive import os import time # 指定需要监测的文件夹 image_path = './im ...

  9. Yii2使用a链接发送post请求

    <?=Html::a(' <img class="list-group-item-icon" src="/frontend/web/images/kplus/ ...

  10. Synchronized用法原理和锁优化升级过程(面试)

    简介 多线程一直是面试中的重点和难点,无论你现在处于啥级别段位,对synchronized关键字的学习避免不了,这是我的心得体会.下面咱们以面试的思维来对synchronized做一个系统的描述,如果 ...