【随想】每日两题Day.14

简介: 【随想】每日两题Day.14

题目151. 反转字符串中的单词

给你一个字符串 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) 额外空间复杂度的 原地 解法。


代码:

class Solution {
    public String reverseWords(String s) {
        s = s.trim(); //去除首尾空格
        int i = s.length() - 1;
        int j = i;
        StringBuilder res = new StringBuilder();
        while(i >= 0) {
            while(i >= 0 && s.charAt(i) != ' ') i--;
            res.append(s.substring(i + 1, j + 1) + " "); //substring 函数是左闭右开的
            while(i >= 0 && s.charAt(i) == ' ') i--;
            j = i;
        }
        return res.toString().trim();
    }
}

思考:

此方法先用 s.trim() 方法去除首尾多余空格。然后利用双指针法来去除单词间的多余空格。注意:substring 函数是左闭右开的。

进阶方法:先翻转整体字符串,再翻转每一个单词。

题目:LCR 182. 动态口令

某公司门禁密码使用动态口令技术。初始密码为字符串 password,密码更新均遵循以下步骤:

  • 设定一个正整数目标值 target
  • passwordtarget 个字符按原顺序移动至字符串末尾

请返回更新后的密码字符串。

示例 1:

输入: password = "s3cur1tyC0d3", target = 4

输出: "r1tyC0d3s3cu"

示例 2:


输入: password = "lrloseumgh", target = 6

输出: "umghlrlose"

提示:


1 <= target < password.length <= 10000

代码:

class Solution {
    public String dynamicPassword(String s, int n) {
        StringBuilder sb = new StringBuilder(s);
        reverseString(sb,0,n-1);
        reverseString(sb,n,s.length()-1);
        return sb.reverse().toString();
    }
    public void reverseString(StringBuilder sb,int start,int end) {
        while(start < end) {
            char tmp = sb.charAt(start);
            sb.setCharAt(start,sb.charAt(end));
            sb.setCharAt(end,tmp);
            start++;
            end--;
        }
    }
}

思考:

此方法与上题进阶方法一致,先翻转整个字符串,再翻转前n个字符,后n个字符。

利用 StringBuilder 类中的 setCharAt(下标,新字符) 方法来做字符串翻转。

目录
相关文章
|
缓存 安全 Linux
Linux内存管理宏观篇(一):不同角度去看内存(硬件)
Linux内存管理宏观篇(一):不同角度去看内存(硬件)
249 0
|
Ubuntu Shell 数据库
Python Qt5 入门教程
Python Qt5 入门教程
380 1
|
前端开发 JavaScript 索引
React 中 keys 的作用是什么?
React 中 keys 的作用是什么?
351 0
|
机器学习/深度学习 编解码 人工智能
视频生成新玩家:Sora 原理探索与效果对比
视频生成新玩家:Sora 原理探索与效果对比
733 0
视频生成新玩家:Sora 原理探索与效果对比
|
存储 缓存 网络安全
Git(1) 常见问题及解决办法_详细版
Git(1) 常见问题及解决办法_详细版
2268 2
jvm配置参数,查看大对象直接分配到老年代
jvm配置参数,查看大对象直接分配到老年代
303 0
|
机器学习/深度学习 人工智能 搜索推荐
《统计学简易速速上手小册》第8章:贝叶斯统计(2024 最新版)
《统计学简易速速上手小册》第8章:贝叶斯统计(2024 最新版)
440 0
|
存储 弹性计算 Serverless
Serverless 应用引擎使用问题之如何解决在回滚之后实例部署信息中没有显示任何实例
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
Serverless API 开发工具
Serverless 应用引擎产品使用合集之如何设置环境变量
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
存储 安全 C语言
C语言------函数
C语言------函数