力扣之917. 仅仅反转字母


917. 仅仅反转字母

1.题目

给你一个字符串 s ,根据下述规则反转字符串:
1.所有非英文字母保留在原有位置。
2.所有英文字母(小写或大写)位置反转。
返回反转后的 s 。

示例 1:
输入:s = "ab-cd"
输出:"dc-ba"
示例 2:
输入:s = "a-bC-dEf-ghIj"
输出:"j-Ih-gfE-dCba"

2.参考答案

代码如下(示例):

class Solution:
    def reverseOnlyLetters(self, s: str) -> str:
        ans = list(s)
        # 利用双指针
        left, right = 0, len(ans) - 1
        while True:
            while left < right and not ans[left].isalpha():
                left += 1
            while right > left and not ans[right].isalpha():
                right -= 1
            if left >= right:
                break
            ans[left], ans[right] = ans[right], ans[left]
            left += 1
            right -= 1
        return ''.join(ans)

3.知识点

①str.isalpha()

如果字符串至少有一个字符并且所有字符都是字母则返回 True,否则返回 False。

str = "runoob";
print str.isalpha();

str = "runoob菜鸟教程";
print str.isalpha();

输出结果:
True
False
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值