代码随想录算法训练营Day7 | 344.反转字符串、541.反转字符串||、替换数字、151.反转字符串中的单词、右旋字符串

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

LeetCode 344 反转字符串

在这里插入图片描述
本题思路:反转字符串比较简单,定义两个指针,一个 i = 0, 一个 j = s.length-1。然后定义一个临时变量 tmp,进行交换 s[i] 和 s[j]。

class Solution {public void reverseString(char[] s) {int i = 0;int j = s.length-1;while(i <= j){char tmp = s[i];s[i] = s[j];s[j] = tmp;i++;j--;}}
}

LeetCode 541 反转字符串||

在这里插入图片描述

本题思路:最重要的理解题目含义,就是每一次走 2*k 步,如果剩余的字符长度大于等于k,就反转前 k 个字符,如果小于 k , 就将剩下的全部反转。 个人感觉这个剩余字符小于 2k的条件毫无软用,

下面用一个例子来分析下思路,方便更好理解。

  • 初始情况下 i = 0, i 每次走 i += 2 * k 步在这里插入图片描述
  • 判断剩余个数是否大于等于 k =2,其实就是判断(i + k <= array.length) 此时符合条件,反转前 K 个 ,调用 reverseSubStr(i,i+k,array),左闭右开。 在这里插入图片描述
  • i 往后移动 i = i + 2 * k,此时 i = 0 + 4 = 4在这里插入图片描述
  • 继续判断 (i + k <= array.length) ,此时条件符合 4 + 2 <= 6, 反转前 K 个 ,调用 reverseSubStr(i,i+k,array),左闭右开。 在这里插入图片描述
  • 此时 i = i + 2 * k = 4 + 8,不符合循环,结束。最终结果如下在这里插入图片描述
class Solution {public String reverseStr(String s, int k) {// 将字符串转换成数组char[] array = s.toCharArray();for(int i = 0; i < array.length; i+=2*k){// 先判断如果剩余字符个数大于 k,或者小于 2k, 就反转这前 K个// 本题主要理清楚,只要剩余个数大于等于k,if(i + k <= array.length){reverseSubStr(i,i+k,array);continue;}// 如果小于 K,就反转剩下的全部reverseSubStr(i,array.length,array);}return new String(array);}// 左闭右开public static void reverseSubStr(int l,int r, char[] s){while(l <= r-1){char tmp = s[l];s[l] = s[r-1];s[r-1] = tmp;l++;r--;}}
}

KamaCoder 替换数字

在这里插入图片描述
本题思路:使用字符串拼接,使用 StringBuilder,遍历字符串,如果是 小写字母的话直接拼接,即可,如果是数字的话,就拼接 “number”

public class Main{public static void main(String[] args){Scanner scanner = new Scanner(System.in);String s = scanner.nextLine();StringBuilder sb = new StringBuilder();for( Character c  : s.toCharArray()){if(c >= 'a' && c <= 'z' ){sb.append(c);}else{sb.append("number");}}System.out.println(sb);}
}

LeetCode 151 反转字符串中的单词

在这里插入图片描述
本题思路

  1. 去掉前面、后面、单词之间的重复空格
  2. 先整体反转
  3. 再单个单词反转

通过示例 2 ,来画个图分析下思路,下面是初始状态在这里插入图片描述

  • 首先是去空格判断,定义一个 Trim() 方法,来进行去除两端的空格,通过定义两个指针,一个 left ,一个 right, left++, right–。碰到第一个不为空格的就停下。在这里插入图片描述
  • 这是去掉两端空格以后的字符串 s在这里插入图片描述
  • 接下里就要进行字符串之间的多余空格进行去重,遍历字符串 s 分为两步; 新定义一个字符串拼接 StringBuilder sb
    • 如果不是空格的话,就直接拼接 sb.append(s.charAt(left)),如下,left++,直到遇到空格停止在这里插入图片描述
    • 可以看到上图,此时就遇到了空格,因为可能有多个空格,我们需要保留一个空格,所以需要判断 (left-1) 这个元素是不是空格,如果是空格,说明空格已经保存了,就跳过不做任何处理,直到遇到的不是空格为止, 可以看到上图 left-1 元素不是空格,所以直接拼接空格,并且left++;在这里插入图片描述
    • 此时上图,又遇到不是空格,直接拼接在这里插入图片描述
  • 最终得到 sb, 去掉多余空格以后的新字符串 sb在这里插入图片描述

  • 接下来就是反转全部字符串,这个逻辑的话和上述反转字符串一样,定义两个指针,一个 left, 一个 right, 然后定义一个 临时变量来交换 这两个数字
  • 最后反转每一个单词。

此处,使用 StringBuilder的时候, 不能 sb.charAt(left) = sb.charAt(right),会有语法错误。必须使用 sb.setCharAt(原值,要改变的值)

class Solution {public String reverseWords(String s) {// 1. 先去掉多余的空格StringBuilder sb = Trim(s);// 2. 先反转全部Reverse(sb,0,sb.length()-1);// 3. 反转每一个单词;// 定义反转起始位置int start = 0;// 定义反转结束位置int end = 0;for (int i = 0; i < sb.length(); i++) {// 找到第一个为空格的下标if (sb.charAt(i) == ' ') {end = i - 1;Reverse(sb, start, end);start = end + 2;}}// 最后一个单词单独进行反转Reverse(sb,start,sb.length()-1);return sb.toString();}// 反转所有单词public static void Reverse(StringBuilder s, int start, int end) {int left = start;int right = end;while (left <= right) {char tmp = s.charAt(left);s.setCharAt(left, s.charAt(right));s.setCharAt(right, tmp);left++;right--;}}// 去空格public static StringBuilder Trim(String s) {int left = 0;int right = s.length() - 1;StringBuilder sb = new StringBuilder();// 去除前面的空格while (left <= right && s.charAt(left) == ' ') {left++;}// 去除后面的空格while (left <= right && s.charAt(right) == ' ') {right--;}// 去重字符串之间的多余空格while (left <= right) {// 如果不等于空格,直接拼接这个字符if (s.charAt(left) != ' ') {sb.append(s.charAt(left));left++;} else { // 此时等于空格,需要判断前面一个是否为空格if (s.charAt(left - 1) != ' ') {sb.append(s.charAt(left));left++;} else {left++;}}}return sb;}
}

虽然整体逻辑不难,但是写代码的时候,出现了很多错误,考虑不周到。还得多写几遍,没那么简单。

KamaCoder 右旋字符串

在这里插入图片描述
本题思路

  1. 先整体反转
  2. 再反转前 k 个
  3. 再反转后 length - k 个

可以通过下图分析得到,为什么这么做!在这里插入图片描述

public static void main (String[] args) {/* code */Scanner scanner = new Scanner(System.in);String s = scanner.nextLine();int k = scanner.nextInt();     // 1. 先整体旋转s = reverse(s,0,s.length()-1);// 2. 再分别反转s = reverse(s,0,k-1);s = reverse(s,k,s.length()-1);System.out.println(s);}// 此处左闭右闭public static String reverse(String s, int start,int end){char[] array = s.toCharArray();int left = start;int right = end;while (left < right) {char tmp = array[left];array[left] = array[right];array[right] = tmp;left++;right--;}return new String(array);}

写这道题的时候,直接用 String 来进行交换,出现了语法错误。因为 String 是不可变的,不能交换里面的内容!

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



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

相关文章

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

使用Java实现Navicat密码的加密与解密的代码解析

《使用Java实现Navicat密码的加密与解密的代码解析》:本文主要介绍使用Java实现Navicat密码的加密与解密,通过本文,我们了解了如何利用Java语言实现对Navicat保存的数据库密... 目录一、背景介绍二、环境准备三、代码解析四、核心代码展示五、总结在日常开发过程中,我们有时需要处理各种软

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

Java 压缩包解压实现代码

《Java压缩包解压实现代码》Java标准库(JavaSE)提供了对ZIP格式的原生支持,通过java.util.zip包中的类来实现压缩和解压功能,本文将重点介绍如何使用Java来解压ZIP或RA... 目录一、解压压缩包1.zip解压代码实现:2.rar解压代码实现:3.调用解压方法:二、注意事项三、总

Linux实现简易版Shell的代码详解

《Linux实现简易版Shell的代码详解》本篇文章,我们将一起踏上一段有趣的旅程,仿照CentOS–Bash的工作流程,实现一个功能虽然简单,但足以让你深刻理解Shell工作原理的迷你Sh... 目录一、程序流程分析二、代码实现1. 打印命令行提示符2. 获取用户输入的命令行3. 命令行解析4. 执行命令

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动

利用Python实现可回滚方案的示例代码

《利用Python实现可回滚方案的示例代码》很多项目翻车不是因为不会做,而是走错了方向却没法回头,技术选型失败的风险我们都清楚,但真正能提前规划“回滚方案”的人不多,本文从实际项目出发,教你如何用Py... 目录描述题解答案(核心思路)题解代码分析第一步:抽象缓存接口第二步:实现两个版本第三步:根据 Fea