代码随想录算法训练营第八天| 344.反转字符串、541. 反转字符串II、 卡码网:54.替换数字、151.翻转字符串里的单词、卡码网:55.右旋转字符串

本文主要是介绍代码随想录算法训练营第八天| 344.反转字符串、541. 反转字符串II、 卡码网:54.替换数字、151.翻转字符串里的单词、卡码网:55.右旋转字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

344.反转字符串

在这里插入图片描述

题目链接: 344.反转字符串
文档讲解:代码随想录
状态:so easy

题解:

    public void reverseString(char[] s) {int left = 0, right = s.length - 1;char temp = s[0];while (left <= right) {temp = s[left];s[left] = s[right];s[right] = temp;left++;right--;}}

541. 反转字符串II

在这里插入图片描述

题目链接: 541. 反转字符串II
文档讲解:代码随想录
状态:so easy

思路:每次选取2k个字符,翻转前k个,如果剩余长度不足 k,则反转剩余部分

    public String reverseStr(String s, int k) {// 将字符串转换为字符数组char[] chars = s.toCharArray();int i = 0;// 遍历字符数组,按规则进行反转while (i < s.length()) {// 反转从i到i+k-1的字符,如果剩余字符不足k个,则反转到字符串末尾reverse(chars, i, Math.min(i + k, s.length()) - 1);// 跳过下一个k个字符i += 2 * k;}// 将字符数组转换为字符串并返回return new String(chars);}public void reverse(char[] chars, int start, int end) {// 反转指定范围的字符while (start <= end) {char temp = chars[start];chars[start] = chars[end];chars[end] = temp;start++;end--;}}

卡码网:54.替换数字

在这里插入图片描述

题目链接: 卡码网:54.替换数字
文档讲解:代码随想录
状态:so easy

题解:

    public String replace(String s) {char[] chars = s.toCharArray();StringBuilder sb = new StringBuilder();for (char c : chars) {sb.append(Character.isDigit(c) ? "number" : c);}return sb.toString();}

151.翻转字符串里的单词

在这里插入图片描述

题目链接: 151.翻转字符串里的单词
文档讲解:代码随想录
状态:还可以

双指针题解:

public String reverseWords(String s) {// 去掉字符串两端的空格并将其转换为字符数组char[] chars = s.trim().toCharArray();// front 和 rear 初始化为字符数组的最后一个位置int front = chars.length - 1;int rear = chars.length - 1;// 用于存储结果字符串StringBuilder sb = new StringBuilder();// 从后向前遍历字符数组while (front >= 0) {// 找到当前单词的起始位置while (front >= 0 && chars[front] != ' ') {front--;}// 将单词添加到 StringBuilder 中,并在末尾添加一个空格sb.append(chars, front + 1, rear - front).append(' ');// 跳过单词之间的空格while (front >= 0 && chars[front] == ' ') {front--;}// 更新 rear 到下一个单词的末尾rear = front;}// 将结果转换为字符串并去掉末尾多余的空格return sb.toString().trim();}

使用split+正则:

    public String reverseWords(String s) {// 使用StringBuilder构建最终结果StringBuilder sb = new StringBuilder();// 使用正则表达式分割字符串为单词数组String[] strings = s.split("\\s+");// 从数组末尾开始,遍历单词并添加到StringBuilder中for (int i = strings.length - 1; i >= 0; i--) {sb.append(strings[i]).append(' ');}// 去除StringBuilder末尾的空格并返回结果字符串return sb.toString().trim();}

卡码网:55.右旋转字符串

在这里插入图片描述

题目链接: 55.右旋转字符串
文档讲解:代码随想录
状态:so easy

题解:

    // 定义一个名为rightHand的方法,该方法接受一个字符串s和一个整数k作为参数public String rightHand(String s, int k) {// 创建一个StringBuilder对象用于构建新的字符串StringBuilder sb = new StringBuilder();// 将字符串s转换为字符数组char[] chars = s.toCharArray();// 使用StringBuilder的append方法,先截取字符数组chars的最后k个字符// 然后截取字符数组chars的前chars.length - k个字符,并将它们拼接起来sb.append(chars, chars.length - k, k).append(chars, 0, chars.length - k);// 返回拼接后的字符串return sb.toString();}

这篇关于代码随想录算法训练营第八天| 344.反转字符串、541. 反转字符串II、 卡码网:54.替换数字、151.翻转字符串里的单词、卡码网:55.右旋转字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016600

相关文章

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型