题解 | #反转字符串#

反转字符串

http://www.nowcoder.com/practice/c3a6afee325e472386a1c4eb1ef987f3

题目的主要信息:
  • 输入一个只包含小写字母的字符串
  • 输出该字符串反转后的字符串
举一反三:

学习完本题的思路你可以解决如下题目:

BM87. 合并两个有序数组

BM88. 判断是否为回文字符串

方法一:双指针交换(推荐使用)

知识点:双指针

双指针指的是在遍历对象的过程中,不是普通的使用单个指针进行访问,而是使用两个指针(特殊情况甚至可以多个),两个指针或是同方向访问两个链表、或是同方向访问一个链表(快慢指针)、或是相反方向扫描(对撞指针),从而达到我们需要的目的。

思路:

字符串反转即逆序,前后顺序是反的,也就是前面的字符换到了后面,后面的字符换到了前面,那既然这样我们就将前后的顺序依次对称交换,这时候就需要使用到了对撞双指针,从前后同时遍历。

具体做法:

  • step 1:准备两个指针,从字符串一首一尾同时出发。
  • step 2:每次交换二者指向的字符,直到二者相遇,这样刚好可以将字符串首尾交换,完成反转。

图示:

alt

Java代码实现:

import java.util.*;
public class Solution {
    public String solve (String str) {
    //左右双指针
    char[] s = str.toCharArray();
    int left = 0;
    int right = str.length() - 1;
    //两指针往中间靠
    while(left < right){  
        char c = s[left];
        //交换位置
        s[left] = s[right];
        s[right] = c;
        left++;
        right--;
    }
    return new String(s);
    }
}

C++代码实现:

class Solution {
public:
    string solve(string str) {
        //左右双指针
        int left = 0;
        int right = str.length() - 1;
        //两指针往中间靠
        while(left < right){  
            //交换两边字符
            swap(str[left], str[right]); 
            left++;
            right--;
        }
        return str;
    }
};

Python实现代码:

class Solution:
    def solve(self , str: str) -> str:
        #左右双指针
        left = 0
        right = len(str) - 1
        #两指针往中间靠
        while left < right: 
            l_s = list(str)
            temp = l_s[left]
            l_s[left] = l_s[right]
            #交换两边字符
            l_s[right] = temp
            str = ''.join(l_s)
            left += 1
            right -= 1
        return str

复杂度分析:

  • 时间复杂度:O(n)O(n)nn为字符串长度,一共循环n/2n/2
  • 空间复杂度:O(1)O(1),常数级变量,没有使用额外辅助空间
方法二:逆序拼接(扩展思路)

思路:

方法一是在原串上面操作,如果原串不能动的情况下,我们可以新开辟一个串,逆序遍历原串,将结果拼接就好。

具体做法:

  • step 1:我们可以从后往前遍历原始字符串。
  • step 2:准备一个空串依次在其前面添加遍历到的字符,新串就是逆序字符串。

Java代码实现:

import java.util.*;
public class Solution {
    public String solve (String str) {
        //从一个空串开始
        String output = ""; 
        //逆序遍历字符串
        for(int i = str.length() - 1; i >= 0; i--) 
            //将字符加到新串后面
            output += str.charAt(i); 
        return output;
    }
}

C++代码实现:

class Solution {
public:
    string solve(string str) {
        //从一个空串开始
        string output = "";
        //逆序遍历字符串
        for(int i = str.length() - 1; i >= 0; i--) 
            //将字符加到新串后面
            output += str[i]; 
        return output;
    }
};

Python实现代码:

class Solution:
    def solve(self , str: str) -> str:
        #从一个空串开始
        output = "" 
        i = len(str) - 1
        #逆序遍历字符串
        while i >= 0 : 
            #将字符加到新串后面
            output += str[i] 
            i -= 1
        return output

复杂度分析:

  • 时间复杂度:O(n)O(n)nn为字符串的长度,一次遍历
  • 空间复杂度:O(n)O(n),output记录新串,长度等于原串
全部评论
双指针那个,Java实现的话String没法直接修改字符,还是要借助转化的char数组,所以空间复杂度还是O(n)吧🤷‍♂️
点赞 回复 分享
发布于 2022-06-15 22:35

相关推荐

工作基本定了,比较满意。这深度学习真是难搞啊,论文看不懂,代码看不懂,不会改,创新点???&nbsp;还有一个月中期,怎么搞,已经抑郁了,没有小论文要求,我真是非常幸运了,不然就我这科研能力…………&nbsp;感觉自己对自己失去信心,无时无刻不在否定自己取得一些成绩都是运气好罢了,真的能顺利毕业吗?严重内耗、无力感爆棚啊…………
AI牛可乐:哎呀,听起来你最近压力好大呀,毕业论文和工作的双重压力一定让你感觉像是背了两座山呢。深度学习确实挺复杂的,就像是要在一片迷雾中找到出路一样。但是,你已经很棒了,工作都定好了,这是很大的成就呢! 论文的事情,别太担心。每个人都有看不懂代码和论文的时候,这是正常的。至于创新点嘛,有时候灵感就像小猫一样,需要一点一点地哄出来的。你可以先试试把你看过的资料整理一下,说不定就能找到新的思路呢。 中期答辩前,你可以列个计划,一步一步来,把大问题分解成小问题,一点一点克服。记得,你不是一个人在战斗,你的导师、同学都是你的战友哦。 至于信心嘛,别否定自己,每个人都会有低谷的时候。你已经取得的成绩,都是你实力的体现。毕业不是问题,只要你不放弃,就一定能顺利走过去的。加油哦,我相信你可以的! 对了,如果你愿意的话,可以点击我的头像,我们私信聊,也许我能帮你出出主意,或者就是简单地聊聊天,分散一下你的注意力也好呀。🐮💪🌟
点赞 评论 收藏
分享
挣K存W养DOG:入职送金条全球游,路过缅甸停一下🐔
点赞 评论 收藏
分享
1 1 评论
分享
牛客网
牛客企业服务