当前位置:网站首页>力扣151-颠倒字符串中的单词
力扣151-颠倒字符串中的单词
2022-08-02 11:41:00 【张怼怼√】
题目描述
给你一个字符串 s ,颠倒字符串中 单词 的顺序。
单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。
返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。
注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
解题思路
- 本题主要考察StringBuffer和Deque的知识,创建一个StringBuffer str 和 Deque deque;
- 将原字符串按空格分隔放进String数组中;
- 借助deque栈,将String中的元素进栈;
- 将栈中元素append到str;
- 将str转为String。
输入输出示例
代码
class Solution {
public String reverseWords(String s) {
String[] stringArray = s.split(" ");
StringBuffer str = new StringBuffer();
int len = stringArray.length;
Deque<String> deque = new LinkedList<>();
for(String i : stringArray){
if(!"".equals(i)) deque.addFirst(i);
}
while(!deque.isEmpty()){
str.append(deque.pop()).append(" ");
}
if(str.length() != 0){
str.deleteCharAt(str.length()-1);
}
return str.toString();
}
}
边栏推荐
猜你喜欢
随机推荐
CCF paper conference IEEE how to query all articles of a conference journal
Thymeleaf
jvmxmx和xms参数分析(设定优化校准)
Shell编程之条件语句
Oracle 19c 连接PDB
【Acunetix-Forgot your password】
Oracle 单实例19.11升级到19.12
ES2020-23简单易懂又实用的精选特性讲解 日常开发必备干货!
SQL function $TRANSLATE
解决anaconda下载pytorch速度极慢的方法
Oracle 19c配置ob server
DTG-SSOD:最新半监督检测框架,Dense Teacher(附论文下载)
企业级数据治理工作怎么开展?Datahub这样做
学习经验分享之七:YOLOv5代码中文注释
运行yum报错Error: Cannot retrieve metalink for reposit
企业级数据治理工作怎么开展?Datahub这样做
当POC遇见RPA:RPA项目顺利实施的关键
npm install报错npm ERR Could not resolve dependency npm ERR peer
暑期总结3
JVM简介