第一题344.反转字符串

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。

不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

ψ(`∇´)ψ 我的思路

  • 取到字符串的中点,依次交换前后两部分的位置
package string;

public class ReverseString {
public static void reverseString(char[] s) {
char temp;
for (int i = 0; i < (s.length)/2; i++) {
temp = s[s.length-i-1];
s[s.length-i-1] = s[i];
s[i] = temp;
}
}
}

时间复杂度为O(n)

  • 我记得有个reverse方法可以反转字符串,但是当时做题的时候没有找到使用方法,提交后查了一下,reverse是StringBuilder和String Buffer的方法
  • 关于交换我看代码随想录上用的是异或
     s[s.length-i-1] ^= s[i];
s[i] ^= s[s.length-i-1];
s[s.length-i-1] ^= s[i];
  • 我用异或试了一下,发现代码效率并没有明显的提升,而且异或交换一直有争议,所以以下题目我还是用最原始的交换方法

第二题 541. 反转字符串 II

给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。

如果剩余字符少于 k 个,则将剩余字符全部反转。

如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。

  • 真费劲呐,读题读了半天,这题目翻译过来就是

每隔2k个反转前k个,尾数不够k个时候全部反转

ψ(`∇´)ψ 我的思路

package string;

public class ReverseStr {
public static String reverseStr(String s, int k) {
StringBuilder sb = new StringBuilder();
StringBuilder res = new StringBuilder();
char[] chars = s.toCharArray();
for (int i = 0; i < chars.length; i++) {
if((i+1)%(2*k)==0){//每隔2k
sb.append(chars,(i-2*k+1),k).reverse();
res.append(sb);//反转前k个字符串
sb.delete(0,k);//清空字符串
res.append(chars,(i-k+1),k);//拼接后k个字符串
}
}
//长度不足2k的剩下的字符串
String left = s.substring(res.length());
if(left.length()>=k){
sb.append(chars,(res.length()),k).reverse();
res.append(sb);//反转前k个字符串
sb.delete(0,k);//清空字符串
int len = res.length();
res.append(chars,(res.length()),(s.length()-len)); } else {
sb.append(left).reverse();
res.append(sb);//把剩下的所有的字符串反转并追加
}
return res.toString();
} public static void main(String[] args) {
String res = reverseStr("abcd", 2);
System.out.println(res);
}
}

时间复杂度为O(n)

  • 本来想着一个StringBuilder 就能解决问题,结果发现反转的时候,需要局部反转再拼接,所以只能用两个StringBuilder

第三题 剑指 Offer 05. 替换空格

请实现一个函数,把字符串 s 中的每个空格替换成"%20"。

ψ(`∇´)ψ 我的思路

package string;

public class ReplaceSpace {

    public static String replaceSpace(String s) {//方法一:遍历替换
StringBuilder sb = new StringBuilder();
char[] chars = s.toCharArray();
for (int i = 0; i < chars.length; i++) {
if (chars[i]==' '){
sb.append("%20");
} else {
sb.append(chars[i]);
}
}
return sb.toString();
} public static String replaceSpace2(String s) {//方法二:API
String replace = s.replace(" ","%20");
return replace;
} public static void main(String[] args) {
String s = "We are happy.";
System.out.println(replaceSpace2(s));
}
}

时间复杂度为O(n)

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

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

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

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

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

  • 他来了他来了,他带着中等题走来了‍♀️

ψ(`∇´)ψ 我的思路

  • 把原始字符串打散后倒序遍历,不为空的输出并拼上空格,删除最后一个空格
package string;

public class ReverseWords {

    public static String reverseWords(String s) {
StringBuilder sb = new StringBuilder();
String[] strs = s.split(" ");//以空格为界把原字符串打散成字符串数组
for (int i=strs.length-1 ; i>=0 ; i--) {
if(!strs[i].equals("")){
sb.append(strs[i]);
sb.append(" ");
}
}
sb.deleteCharAt(sb.length()-1);//删除最后一个空格
return sb.toString();
} public static void main(String[] args) {
String s = "a good example";
System.out.println(reverseWords(s));
}
}

时间复杂度为O(n)

  • 没找到这题的难点在哪,再给我这样的题我就要飘了啊‍♀️

第五题 剑指 Offer 58 - II. 左旋转字符串

字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。

ψ(`∇´)ψ 我的思路

public static String reverseLeftWords(String s, int n) {
StringBuilder sb = new StringBuilder();
sb.append(s.substring(n));//先把不需要遇到的字符串拼到前面来
sb.append(s,0,n);
return sb.toString();
}

时间复杂度为O(1)

  • 因为这题过于简单我就看了代码随想录的解法

class Solution {
public String reverseLeftWords(String s, int n) {
int len=s.length();
StringBuilder sb=new StringBuilder(s);
reverseString(sb,0,n-1);
reverseString(sb,n,len-1);
return sb.reverse().toString();
}
public void reverseString(StringBuilder sb, int start, int end) {
while (start < end) {
char temp = sb.charAt(start);
sb.setCharAt(start, sb.charAt(end));
sb.setCharAt(end, temp);
start++;
end--;
}
}
}
  • 方法很巧,就是两个部分分别反转后整体反转,因为涉及到三次反转,所以把反转的方法提取出来复用

  • 啊这就很尴尬了,代码随想录的方法巧是巧,可是既没有降低我的时间复杂度,也没有降低我的空间复杂度,我要这么巧的方法做什么啊

总结

  • 只要可以用StringBuilder,就没有我小瑶仙女儿解不出来的字符串啊哈哈哈哈哈ヾ(≧▽≦*)o

代码随想录第八天 |344.反转字符串 、541. 反转字符串II、剑指Offer 05.替换空格 、151.翻转字符串里的单词 、剑指Offer58-II.左旋转字符串的更多相关文章

  1. 剑指Offer 2. 替换空格 (字符串)

    题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 题目地址 https://ww ...

  2. 剑指offer-第六章面试中的各项能力(翻转单词的顺序VS左旋转字符串)

    //题目1:翻转单词顺序例如“Hello world!”翻转后为world! Hello. //思路:首先翻转整个字符串,然后再分别翻转每个单词. //题目2:左旋转字符串,是将字符串的前面几个(n) ...

  3. 【算法训练营day8】LeetCode344. 反转字符串 LeetCode541. 反转字符串II 剑指Offer05. 替换空格 LeetCode151. 翻转字符串里的单词 剑指Offer58-II. 左旋转字符串

    [算法训练营day8]LeetCode344. 反转字符串 LeetCode541. 反转字符串II 剑指Offer05. 替换空格 LeetCode151. 翻转字符串里的单词 剑指Offer58- ...

  4. 编程算法 - 左旋转字符串 代码(C)

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u012515223/article/details/37689725 左旋转字符串 代码(C) 本文 ...

  5. 笔试算法题(13):反转链表 & 左旋转字符串

    出题:反转链表(递归和非递归解法): 分析:有递归跟非递归实现,注意对原始链表头节点的处理,因为其他节点都指向下一个节点,其需要指向NULL: 解题: struct Node { int v; Nod ...

  6. 剑指Offer面试题:34.翻转单词顺序VS左旋转字符串

    一.题目一:翻转单词顺序 1.1 题目说明 题目一:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变.为简单起见,标点符号和普通字母一样处理.例如输入字符串"I am a st ...

  7. 【面试题042】翻转单词顺序VS左旋转字符串

    [面试题042]翻转单词顺序VS左旋转字符串 题目一:     输入一个英文句子,反转句子中单词的顺序,但单词内字符的顺序不变.为简单起见,标点符号和普通字母一样处理.     例如输入字符串“I a ...

  8. 辗转相除法(GCD)求左旋转字符串

    本文写于2017-01-18,从老账号迁移到本账号,原文地址:https://www.cnblogs.com/huangweiyang/p/6297874.html 今天在牛客网上做了一道题,题意就是 ...

  9. 《剑指offer》第五十八题(左旋转字符串)

    // 面试题58(二):左旋转字符串 // 题目:字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部. // 请定义一个函数实现字符串左旋转操作的功能.比如输入字符串"abcde ...

随机推荐

  1. Python 实现列表与二叉树相互转换并打印二叉树封装类-详细注释+完美对齐

    # Python 实现列表与二叉树相互转换并打印二叉树封装类-详细注释+完美对齐 from binarytree import build import random # https://www.cn ...

  2. 不止跑路,拯救误操作rm -rf /*的小伙儿

    摘要:误执行了 rm -rf /* 之后,除了跑路还能怎么办? 本文分享自华为云社区<拯救被 rm -rf 伤到的小伙>,作者:Gauss 松鼠会. 灵魂画师再次上线   在开饭前我们先了 ...

  3. CSS(上)

    css sprite是什么,有什么优缺点 概念:将多个小图片拼接到⼀个图⽚中.通过 background-position 和元素尺寸调节需要显示的背景图案. 优点: 减少 HTTP 请求数,极⼤地提 ...

  4. JVM 系列(4)一看就懂的对象内存布局

    请点赞关注,你的支持对我意义重大. Hi,我是小彭.本文已收录到 GitHub · AndroidFamily 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注公众号 [彭旭锐] ...

  5. mybatisplus-sql注入器

    sql注入器 使用mybatisplus只需要继承BaseMapper接口即可使用:但是有新的需求需要扩展BaseMapper里面的功能时可使用sql注入器. 扩展BaseMapper里面的功能 点击 ...

  6. 「雅礼集训 2017 Day2」水箱 (数据结构+dp ,一个log)

    题面 题解 在网上看到有些做法,有什么平衡树.启发式合并等等总之复杂度O(Tnlog^2(n))的不优做法,这里我就用一个O(Tnlogn)的做法好了 其实大体上推导的思路都是一样的. 我们很容易发现 ...

  7. 【unity游戏入门】2 使用代码编写Hello Unity游戏

    作者 罗芭Remoo 2021年9月24日 第一章.许可证的安装 下载好Unity之后,我们还需要一个前置操作才可以进入Unity引擎----许可证. 当然不用担心,Unity是一个开放的引擎,一切以 ...

  8. 区块相隔虽一线,俱在支付同冶熔,Vue3.0+Tornado6前后端分离集成Web3.0之Metamask区块链虚拟三方支付功能

    最近几年区块链技术的使用外延持续扩展,去中心化的节点认证机制可以大幅度改进传统的支付结算模式的经营效率,降低交易者的成本并提高收益.但不能否认的是,区块链技术也存在着极大的风险,所谓身怀利器,杀心自起 ...

  9. luogu [ZJOI2007] 矩阵游戏

    [ZJOI2007] 矩阵游戏 题目描述 小 Q 是一个非常聪明的孩子,除了国际象棋,他还很喜欢玩一个电脑益智游戏――矩阵游戏.矩阵游戏在一个 \(n \times n\) 黑白方阵进行(如同国际象棋 ...

  10. Android平台Camera2数据如何对接RTMP推流到服务器

    1. Camera2架构 在Google 推出Android 5.0的时候, Android Camera API 版本升级到了API2(android.hardware.camera2), 之前使用 ...