将字符串向左旋转n个字符(特殊字符除外)

2024-05-13 18:42:54 发布

您现在位置:Python中文网/ 问答频道 /正文

嗨,我需要帮助将字符串向左旋转n次,我已经这样做了:顺便说一句,字符串是字符串列表:

 finaltext = ""
 for i in strings:
    first = i[0 : n] 
    second = i[n :] 
    i = second + first
    finaltext += i

但是,我不知道如何做到这一点,以便在给定的字符串中,例如:“The intern”,空格或任何特殊字符都不会移动。你知道吗

s1 = "The intern"

现在我的输出是: ternThe in

我想要的输出: ern eThein

有什么想法吗?我当前创建了一个函数,它指示当一个特殊字符及其索引出现在字符串中时,我在for循环中使用它来知道当前字符是一个特殊字符,但是当涉及到旋转时,如何避免该字符


Tags: the字符串in列表for字符first空格
1条回答
网友
1楼 · 发布于 2024-05-13 18:42:54

一个有趣的问题。如何在忽略特定字符的情况下旋转字符串?你知道吗

在这里,我们移除、旋转、重新插入字符。你知道吗

给定的

import collections as ct


def index(s):
    """Return a reversed dict of (char, [index, ...]) pairs."""
    dd = ct.defaultdict(list)
    for i, x in enumerate(s):
        dd[x].append(i)
    return dd


s1 = "The intern"
s2 = "Hello world!"

代码

def rotate(s, n=0, ignore=""):
    """Return string of rotated items, save ignored chars."""
    s0 = s[:]

    # Remove ignored chars
    for ig in ignore:
        s = s.replace(ig, "")

    # Rotate remaining string, eqiv. to `res = s[-n:] + s[:-n]`
    tail = s[-n:]
    head = ""

    for c in s[:-n]:         
        head += c    
    res = tail + head


    # Reinsert ignored chars
    if ignore:
        res = list(res)
        lookup = index(s0)
        for ig in ignore:
            for idx in lookup[ig]:
                res.insert(idx, ig)
        res = "".join(res)
    return res

测试

assert rotate(s1, n=0, ignore="") == "The intern"
assert rotate(s1, n=1, ignore="") == "nThe inter"
assert rotate(s1, n=1, ignore=" ") == "nTh einter"
assert rotate(s1, n=3, ignore=" ") == "ern Theint"

assert rotate(s2, n=12, ignore="") == "Hello world!"
assert rotate(s2, n=1, ignore="") == "!Hello world"
assert rotate(s2, n=1, ignore="H !") == "Hdell oworl!"
assert rotate(s2, n=1, ignore="!") == "dHello worl!"

相关问题 更多 >