算法--双指针2

目录

前言

解题

分析


前言

OK啊,各位,我又来给你们分享我的算法了,今天依旧是双指针算法。这一章是关于字符串的处理的双指针。下面是题目

345. 反转字符串中的元音字母 - 力扣(LeetCode)


解题

如果想直接编写的,可以直接在自己的编译器中编程序了,题目我放这里了。然后说一下我框的这几个。首先,我看的是有点懵的。仔细想一想,他的意思就是说,我们要找出一个字符串中的元音字母,然后翻转就好了。

那么 好,我们应该怎么实现呢?我可以像上次一样,定义两个变量,然后去找有那些元音字母

python 复制代码
left = 0
right = len(s) - 1
while left <= right:

OK,那下面我们应该怎么写呢?因为我们主要针对的就是元音字母对不对,所以我的left和right指针应该指向的是元音字符,所以我们要移动他们到对应的位置。

python 复制代码
left = 0
right = len(s) - 1
while left <= right:
    if s[left] not in 'aeiouAEIOU':
        left += 1
        continue
    if s[right] not in 'aeiouAEIOU':
        right -= 1
        continue

是吧,这样我们就可以交换了,但是我们发现这个是字符串我们是无法直接交换的,因为他是不可变变量,所以我们可以把它转成list。即s = list(s)。这样我们就可以直接交换了。

OK,下面展示完整的代码

python 复制代码
class Solution:
    def reverseVowels(self, s: str) -> str:
        word = list(s)
        left = 0
        right = len(s) - 1
        while left <= right:
            if word[left] not in 'aeiouAEIOU':
                left += 1
                continue
            if word[right] not in 'aeiouAEIOU':
                right -= 1
                continue
            word[left], word[right] = word[right], word[left]
            left += 1
            right -= 1
        return ''.join(word)
            
            

那么OK,这个题目我们就解决了,我们真是太棒了。

分析

来说一下问题哈,首先为什么要使用到双指针,使用别的方法不行吗?答案是,双指针不是唯一答案但是他是最优的答案。你们如果想的话,是可以这样的,就额外开空间,找出所有元音字母的位置,并要把值给带出来,建议使用字典,然后创建一个ans数组,先填充不变的字母,如果遇到事元音字母的位置你就去你创建的字典哪里查找,并填入位置为最后面的元音字母,就是倒着填入

有点麻烦,所以我没有写,如果想锻炼自己的编程,可以去试一下

然后就是这里,为什么我中间要使用if和continue,而不是直接使用while。使用while不是更快更简洁吗?嗯,没错,可以使用到while,但是如果要使用到while的话,就要考虑到更多的因数了,不太建议新手去使用,但是我建议新手去学习。

为什么这么说,首先,你的while语句,很明确的说明了,你的left或者right指针要指向对应的值,那我问你,如果你直接使用while而不去考虑边界的话,会出现什么情况?会出现left>right。那么这里就已经违反了题目了。而且如果你不设置它的left和right的区域的话,还会执行出错

python 复制代码
class Solution:
    def reverseVowels(self, s: str) -> str:
        word = list(s)
        left = 0
        right = len(s) - 1
        while left <= right:
            while left < len(s) and word[left] not in 'aeiouAEIOU':
                left += 1    
            while right > 0 and word[right] not in 'aeiouAEIOU':
                right -= 1
            if left <= right:
                word[left], word[right] = word[right], word[left]
                left += 1
                right -= 1
            else:
                break
        return ''.join(word)

那,这个就是while的写法,所以有有点麻烦,但是新手确实应该去掌握。最后的if-else呢就是一个剪枝,因为left>right的话就已经不合法了。(没有上面执行效率高)但也值得学习。有不懂的可以问,谢谢大家观看^v^

相关推荐
Book思议-5 分钟前
【数据结构实战】循环队列FIFO 特性生成六十甲子(天干地支纪年法),实现传统文化里的 “时间轮回”
数据结构·算法·
im_AMBER16 分钟前
Leetcode 147 零钱兑换 | 单词拆分
javascript·学习·算法·leetcode·动态规划
zl_vslam31 分钟前
SLAM中的非线性优-3D图优化之IMU预积分SE3推导(二十一)
人工智能·算法·计算机视觉·3d
c++逐梦人33 分钟前
DFS经典例题(八皇后,数独)
算法·蓝桥杯·深度优先
进击的小头34 分钟前
第18篇:PID参数整定与裕度优化的现场调试实战
python·算法
cpp_250137 分钟前
P1796 汤姆斯的天堂梦
数据结构·c++·算法·题解·洛谷·线性dp
凌波粒42 分钟前
LeetCode--19.删除链表的倒数第 N 个结点(链表)
java·算法·leetcode·链表
Fcy6481 小时前
与红黑树有关算法题
算法
爱搞虚幻的阿恺1 小时前
UE入门-如何使用结构体数组创建动态UI
算法
重生之我是Java开发战士2 小时前
【广度优先搜索】多源BFS:矩阵,飞地的数量,地图中的最高点,地图分析
数据结构·算法·矩阵·广度优先