当前位置:网站首页>力扣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();
}
}
边栏推荐
猜你喜欢
随机推荐
[kali-information collection] (1.8) ARP reconnaissance tool _Netdiscover
划分训练集,验证集,测试集
21 Days Learning Challenge - Day 1 Punch (Screen Density)
Oracle 单实例19.11升级到19.12
How to technically ensure the quality of LED display?
腾讯云云函数SCF—入门须知
使用kubesphere图形界面创建一个应用操作流程
LeetCode第三题(Longest Substring Without Repeating Characters)三部曲之一
使用无界队列的线程池会导致内存飙升吗?
云原生(三十) | Kubernetes篇之应用商店-Helm介绍
看我如何用多线程,帮助运营小姐姐解决数据校对系统变慢!
华为eNSP(基础实验通信)
【云驻共创】数据工坊平台,0代码开发数据处理业务“快”人一步
记录代码
阿苹的思考
翁恺C语言程序设计网课笔记合集
Kotlin的协程与生命周期
大疆P4M云遮挡矫正
Shell编程案例
企业级数据治理工作怎么开展?Datahub这样做