当前位置: 首页 > news >正文

力扣: 翻转字符串里的单词

文章目录

  • 需求
  • 分析
  • 代码
  • 结尾

在这里插入图片描述


需求

给你一个字符串 s ,请你反转字符串中 单词 的顺序。

单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。

返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。

注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。

示例 1:
输入:s = “the sky is blue”
输出:“blue is sky the”

示例 2:
输入:s = " hello world "
输出:“world hello”
解释:反转后的字符串中不能存在前导空格和尾随空格。

示例 3:
输入:s = “a good example”
输出:“example good a”
解释:如果两个单词间有多余的空格,反转后的字符串需要将单词间的空格减少到仅有一个。

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

进阶:如果字符串在你使用的编程语言中是一种可变数据类型,请尝试使用 O(1) 额外空间复杂度的 原地 解法。


分析

挺简单的, 就是转换字符串 . 难的地方是把字符串转换为数组, 但是这个空格有多个的 有一个的.
这就要用到 .split("\\s+"), 这个会匹配多个空格.

代码

public String reverseWords(String s) {String[] split = s.trim().split("\\s+");for (int left = 0, right = split.length - 1; left < split.length / 2; left++, right--) {String temp = split[left];split[left] = split[right];split[right] = temp;}return String.join(" ", split);
}

代码解释:

去除首尾空白字符并分割字符串:
String[] split = s.trim().split("\\s+");
s.trim():去掉字符串s首尾的空白字符,确保处理时不会受到这些空白字符的影响。
s.split("\\s+"):使用正则表达式\s+(一个或多个空白字符)将字符串分割成一个字符串数组split。这个数组包含了字符串中的所有单词,空白字符被忽略掉了。
反转单词顺序:

for (int left = 0, right = split.length - 1; left < split.length / 2; left++, right--) {String temp = split[left];split[left] = split[right];split[right] = temp;
}

初始化两个指针:left从数组的开头开始,right从数组的末尾开始。
left < split.length / 2:循环条件是left小于数组长度的一半,因为我们只需要处理数组的一半即可。
在每次循环中:
用temp变量保存当前left指针位置的单词。
将right指针位置的单词赋值给left指针位置。
将temp(原来left指针位置的单词)赋值给right指针位置。
left++和right--:更新指针,left向右移动,right向左移动,逐步完成单词的反转。
将数组转回字符串并返回:
return String.join(" ", split);
String.join(" ", split):将数组split中的单词用一个空格连接成一个新的字符串。这里用空格" "作为分隔符,将单词重新组合成一个字符串,并返回这个结果。

执行结果:

在这里插入图片描述


结尾

以上 是我对这道算法的一些遐想和延伸, 可能不是最优解, 但是算法的优化嘛 本身就是一个思索的过程, 能在这个思索和迭代的过程中有所收获和乐趣就是在成长了, 欢迎大家一起来交流更多的解答…

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Django创建模型
  • 从零开始学数据结构系列之第六章《排序简介》
  • 三维坐标变换
  • linux c++ 通信架构 笔记(14) 第三章 Nginx 开发初步:守护进程的信号使用,介绍 nginx 的选项与信号,后台进程与守护进程的区别
  • websocket 和sip 在协议层面有哪些区别,为什么要各自这样设置协议
  • redis的事务与管道有什么不同?
  • Vscode中搭建ABAP开发环境
  • 开源的 Kafka 管理平台
  • C++字符串的常用操作
  • cesium.js 入门到精通(6)
  • vue3.x项目使用高德地图JS API 2.0
  • 如何使用 Vidu Studio 根据照片和提示词生成视频
  • 深入剖析 MQTT 协议:物联网通信的核心力量
  • 【服务器第一期】Xshell、Xftp下载及连接
  • 无人机巡检:突破传统局限,引领智能监测新时代
  • [译]前端离线指南(上)
  • AngularJS指令开发(1)——参数详解
  • C++回声服务器_9-epoll边缘触发模式版本服务器
  • Git同步原始仓库到Fork仓库中
  • JAVA 学习IO流
  • MYSQL 的 IF 函数
  • MySQL的数据类型
  • Vue 动态创建 component
  • 关于for循环的简单归纳
  • 悄悄地说一个bug
  • 全栈开发——Linux
  • 如何实现 font-size 的响应式
  • -- 数据结构 顺序表 --Java
  • 线上 python http server profile 实践
  • 想写好前端,先练好内功
  • 终端用户监控:真实用户监控还是模拟监控?
  • 深度学习之轻量级神经网络在TWS蓝牙音频处理器上的部署
  • # windows 运行框输入mrt提示错误:Windows 找不到文件‘mrt‘。请确定文件名是否正确后,再试一次
  • ### RabbitMQ五种工作模式:
  • #WEB前端(HTML属性)
  • #免费 苹果M系芯片Macbook电脑MacOS使用Bash脚本写入(读写)NTFS硬盘教程
  • $NOIp2018$劝退记
  • (1)常见O(n^2)排序算法解析
  • (ZT) 理解系统底层的概念是多么重要(by趋势科技邹飞)
  • (八)五种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (保姆级教程)Mysql中索引、触发器、存储过程、存储函数的概念、作用,以及如何使用索引、存储过程,代码操作演示
  • (第8天)保姆级 PL/SQL Developer 安装与配置
  • (二)斐波那契Fabonacci函数
  • (附源码)springboot车辆管理系统 毕业设计 031034
  • (南京观海微电子)——I3C协议介绍
  • (学习日记)2024.01.09
  • (转)http-server应用
  • ******IT公司面试题汇总+优秀技术博客汇总
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost
  • .net MySql
  • .net 无限分类
  • .NET周刊【7月第4期 2024-07-28】
  • .vimrc php,修改home目录下的.vimrc文件,vim配置php高亮显示
  • :“Failed to access IIS metabase”解决方法
  • @FeignClient注解,fallback和fallbackFactory