代码随想录算法训练营day08 | leetcode 344.反转字符串/541. 反转字符串II / 剑指Offer05.替换空格/151.翻转字符串里的单词/剑指Offer58-II.左旋转字符串
基础知识
// String -> char[]
char[] string=s.toCharArray();
// char[] -> String
String.valueOf(string)
注意replace replaceAll区别,都是全局匹配替换,不过replaceAll是正则匹配
LeetCode 344.反转字符串
分析1.0
基础的前后指针元素互换
class Solution {
public void reverseString(char[] s) {
if(s==null){
return;
}
int len=s.length;
if(len==0 || len==1){
return;
}
int left=0, right=len-1;
while(left<right){
char temp=s[right];
s[right]=s[left];
s[left]=temp;
left++;
right--;
}
return;
}
}
LeetCode 541. 反转字符串II
分析1.0
涉及多次反转,考虑写一个根据索引反转字符串的函数,反转部分之后,考虑剩下的元素个数;
String -> StringBuilder 或者采用字符数组的方式处理
class Solution {
public String reverseStr(String s, int k) {
int len=s.length();
if(s==null){
return null;
}
char[] string=s.toCharArray();
int endIndex=len-1;
int startIndex=0;
while(startIndex<=endIndex){
//System.out.println("start position: "+startIndex);
int gap=endIndex-startIndex+1;
//System.out.println("gap: "+gap);
if(gap<k){
reverse(string, startIndex, endIndex);
break;
}else if(gap<2*k && gap>=k){
reverse(string, startIndex, startIndex+k-1);
break;
}else{
reverse(string, startIndex, startIndex+k-1);
startIndex=startIndex+2*k;
}
//System.out.println(string);
}
return String.valueOf(string);
}
public void reverse(char[] s, int left, int right){
while(left<right){
char temp=s[left];
s[left]=s[right];
s[right]=temp;
left++;
right--;
}
}
}
LeetCode
分析1.0
直接用了API
class Solution {
public String replaceSpace(String s) {
return s.replace(" ","%20");
}
}
LeetCode 151.翻转字符串里的单词
分析1.0
遍历,遍历过程中去除多余空格,将获得的一个一个单词采用尾插法加入List<StringBuilder>,最后再使用空格拼接
获取单词首指针、检查合法性、获取尾指针
class Solution {
public String reverseWords(String s) {
if(s==null){
return null;
}
// s=s.trim();
ArrayDeque<String> stack = new ArrayDeque();
int len=s.length();
int leftIndex=0, rightIndex=0;
while(leftIndex<len){
// 获取s中每个单词的起始索引
while(leftIndex<len && s.charAt(leftIndex)==' '){
leftIndex++;
}
// 这里要注意跳出
if(leftIndex>=len){
break;
}
rightIndex=leftIndex;
while(rightIndex<len && s.charAt(rightIndex)!=' '){
rightIndex++;
}// 此时rightIndex指向某个单词的最后一个字符的索引的后面的空格
String temp=s.substring(leftIndex, rightIndex);
System.out.println("----"+temp);
stack.push(temp);
leftIndex=rightIndex;
}
StringBuilder ans = new StringBuilder();
while(!stack.isEmpty()){
ans.append(stack.pop())
.append(" ");
}
// return ans.toString().trim(); 二者都行
return ans.substring(0, ans.length()-1);
}
}
失误
每次获取一个单词前都要检查当前额left指针是否超过了s的长度
substring() 要小写 subString()是错的
分析2.0
反转s,再反转所有的单词
采用trim()方法去除收尾多余空格,再用replaceAll()
LeetCode 剑指Offer58-II.左旋转字符串
分析1.0
相当于逻辑左移所有字符串元素,左移个数如果是元素个数的倍数,那就不移动,即要将移动次数对字符串长度取余,再向左移动,增加字符串空间,取余后的索引为n的元素为新的首元素,将原字符串截断后拼接即可
class Solution {
public String reverseLeftWords(String s, int n) {
int len=s.length();
n=n%len;
String s1=s.substring(0,n);
String s2=s.substring(n,len);
return s2+s1;
}
}
分析2.0
反转两个局部,再整体反转
总结
- 数组长度 arr.length 字符串长度 s.length()
- 双指针-前后指针、快慢指针、滑动窗口 降低时间复杂度利器
- 工具:Arrays、Collections、队列、栈(逆序好帮手)、哈希表/map
- substring() 要小写 subString()是错的
- s.trim().replaceAll("\\s+", " ") 去除收尾多余空格并将字符串内多余空格变成一个空格
常用变量名增量更新
size、val、ans、cnt、cur、pre、next、left、right、index、gap、tar、res、src、len、start、end
代码随想录算法训练营day08 | leetcode 344.反转字符串/541. 反转字符串II / 剑指Offer05.替换空格/151.翻转字符串里的单词/剑指Offer58-II.左旋转字符串的更多相关文章
- 【算法训练营day8】LeetCode344. 反转字符串 LeetCode541. 反转字符串II 剑指Offer05. 替换空格 LeetCode151. 翻转字符串里的单词 剑指Offer58-II. 左旋转字符串
[算法训练营day8]LeetCode344. 反转字符串 LeetCode541. 反转字符串II 剑指Offer05. 替换空格 LeetCode151. 翻转字符串里的单词 剑指Offer58- ...
- 代码随想录第八天 |344.反转字符串 、541. 反转字符串II、剑指Offer 05.替换空格 、151.翻转字符串里的单词 、剑指Offer58-II.左旋转字符串
第一题344.反转字符串 编写一个函数,其作用是将输入的字符串反转过来.输入字符串以字符数组 s 的形式给出. 不要给另外的数组分配额外的空间,你必须原地修改输入数组.使用 O(1) 的额外空间解决这 ...
- Leetcode 344:Reverse String 反转字符串(python、java)
Leetcode 344:Reverse String 反转字符串 公众号:爱写bug Write a function that reverses a string. The input strin ...
- 笔试算法题(13):反转链表 & 左旋转字符串
出题:反转链表(递归和非递归解法): 分析:有递归跟非递归实现,注意对原始链表头节点的处理,因为其他节点都指向下一个节点,其需要指向NULL: 解题: struct Node { int v; Nod ...
- 编程算法 - 左旋转字符串 代码(C)
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u012515223/article/details/37689725 左旋转字符串 代码(C) 本文 ...
- 九度OJ 1362 左旋转字符串(Move!Move!!Move!!!)【算法】
题目地址:http://ac.jobdu.com/problem.php?pid=1362 题目描述: 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运 ...
- leetcode题库练习_左旋转字符串
题目:左旋转字符串 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部.请定义一个函数实现字符串左旋转操作的功能.比如,输入字符串"abcdefg"和数字2,该函数将返 ...
- Leetcode#344. Reverse String(反转字符串)
题目描述 编写一个函数,其作用是将输入的字符串反转过来. 示例 1: 输入: "hello" 输出: "olleh" 示例 2: 输入: "A man ...
- 【LeetCode】151. 翻转字符串里的单词(剑指offer 58-I)
151. 翻转字符串里的单词 知识点:字符串:双指针 题目描述 给你一个字符串 s ,逐个翻转字符串中的所有 单词 . 单词 是由非空格字符组成的字符串.s 中使用至少一个空格将字符串中的 单词 分隔 ...
- [LeetCode] 344 Reverse String && 541 Reverse String II
原题地址: 344 Reverse String: https://leetcode.com/problems/reverse-string/description/ 541 Reverse Stri ...
随机推荐
- JavaScript中的Error错误对象与自定义错误类型
Error Error是JavaScript语言中的一个标准的内置对象,专门用于处理JS开发中的运行时错误. 当我们的JS代码在运行过程中发生错误的话,就会抛出Error对象,整个程序将会中断在错误发 ...
- 【Java SE】Day01 前言、入门程序、常量、变量
回顾一下Java之前学的内容 Day01 前言.入门程序.常量.变量 一.基础知识 莱布尼茨发明二进制,辗转相除与8421位权法互转,1B=1bit=1字节=8位=8byte dos cls清屏dir ...
- 【重难点】函数式接口、函数式编程、匿名内部类、Lambda表达式、语法糖
一.函数式接口 1.概念 仅有一个抽象方法的接口 适用于函数式编程(Lambda表达式) 常见:Runnable.Comparator<>.生产型接口Producer的get方法.消费型接 ...
- 【每日一题】【动态规划】2022年1月30日-NC127 最长公共子串
描述 给定两个字符串str1和str2,输出两个字符串的最长公共子串 题目保证str1和str2的最长公共子串存在且唯一. 方法1:dp数组存子串 import java.util.*; public ...
- Windows Terminal ssh 远程 Linux 和使用 Git
Windows Terminal ssh 远程 Linux 和使用 Git Windows Terminal (中文:终端)是 Win11 自带的 Terminal.可以添加配置文件,然后把远程主机放 ...
- 01-复杂度2 Maximum Subsequence Sum (25分)
Sample Input: 10 -10 1 2 3 4 -5 -23 3 7 -21 Sample Output: 10 1 4 题目有一个测试点是"最大和前面有一段是0",所以 ...
- QT+VS 调用基于Google Breakpad的跨平台Qt崩溃异常捕获调用方案
方案一.基于Google Breakpad的跨平台Qt崩溃异常捕获调用方案 首先上博客:Windows下Qt生成dump文件并定位bug(基于qBreakpad) 这个地方使用的是一个叫qBreakP ...
- [生命科学] 生物基础实验之PCR验证
生物基础实验之PCR验证 文章目录 生物基础实验之PCR验证 实验步骤一 实验步骤二 实验步骤三 配胶 实验步骤四 电泳 实验步骤五 跑胶 实验步骤一 在离心管加入7.5μL Master Mix 溶 ...
- Python自动化操作sqlite数据库
你好,我是悦创. 原文首发:https://bornforthis.cn/column/pyauto/ 1. 什么是数据库 数据库是"按照数据结构来组织.存储和管理数据的仓库",是 ...
- ios网络协议从http变成https
最近发了一个很蛋疼的事,iphone16.x以后的系统浏览器自动将http请求切换为https请求了 工程自测 1.在ihone14 pro max,iOS16.1的手机上用http请求是失败的,在i ...