当前位置:网站首页>力扣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();
}
}边栏推荐
猜你喜欢

Crack detection technology based on deep learning

云原生(三十) | Kubernetes篇之应用商店-Helm介绍

QAbstractScrollArea、QScrollArea

CCF论文会议 IEEE 如何查询某个会议期刊的所有文章

【kali-信息收集】(1.8)ARP侦查工具_Netdiscover

数字化转型中的低代码

Create a devops CI/CD process using the kubesphere GUI

Breaking the Boundary, Huawei's Storage Journey

Shell编程之条件语句

sva assertion data
随机推荐
C#/VB.NET to add more lines more columns image watermark into the Word document
Question about #oracle#, how to solve it?
受邀出席Rust开发者大会|Rust如何助力量化高频交易?
Pytorch 占用cpu资源过多
Outsourced Student Management System Architecture Documentation
sqli-labs(less-11)
Jest 测试框架 beforeEach 的设计原理解析
解决导出excel文件名中文乱码的问题
10份重磅报告 — 展望中国数字经济未来
Failed to configure mysql, what's going on?
AQS-AbstractQueuedSynchronizer
Getting Started with Three.JS Programmatic Modeling
QAbstractScrollArea、QScrollArea
【kali-信息收集】(1.9)Metasploit+搜索引擎工具Shodan
元宇宙“吹鼓手”Unity:疯狂扩局,悬念犹存
SQL函数 TRIM
Thymeleaf
如何在 UE4 中制作一扇自动开启的大门
字母交换--字符串dp
“纯C”实现——三子棋小游戏