问题描述

输入样例:
Only the 11 CAPItal LeTtERS are replaced
输出样例:
Only the 11 XZKItal OeGtVIH are replaced

解题思路

首先想到的是使用字典匹配字符然后遍历替换,其次想到的是使用ASCLL码,后者更为方便简单。

思路一

inp = input()
dist = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M',
        'N' 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']
for i in inp:
    if i in dist:
        index = dist.index(i)
        inp = inp.replace(i, dist[-index - 1])
print(inp)

思路二

str = input()

for i in str:
    num = ord(i)  # 得到ASCIIif (65 <= num <= 90):  # 如果是大写字母
        str = str.replace(i, chr(155 - num))

print(str)

遇到的问题:

在思路二中,我之前的代码是这样的:

str = input()


def replace(str):
    for i in str:
        num = ord(i)  # 得到ASCIIif (num >= 65 & num <= 90):  # 如果是大写字母
            i = chr(155 - num)
    return str


replace(str)
print(str)

后来意识到 i 只是一个变量,转瞬即逝,我并没有把它存住。

然后想到的用 replace()函数:

str = input()

for i in str:
    num = ord(i)  # 得到ASCIIif (65 <= num <= 90):  # 如果是大写字母
        str.replace(i, chr(155 - num))

print(str)

但是还是不对,因为我没有存储 replace()函数的返回值,导致虽然替换了,但是没有存储它,所以结果没有变化。

最终的代码就是上的那个了,看起来完美无缺,但是全部都是做的,为什么?

输入:
Only the 11 CAPItal LeTtERS are replaced
输出:
Only the 11 XZKItal OeGtVIH are replaced

可以看到除了第一个 O 之外其他的都对,那为什么 O 没有换呢?

其实它换了,只是换了两次,负负得正,又回来了。

因为 replace()方***把字符串中所有符合条件的字母替换掉。

比如输入 OL ,我们想要的结果为 LO,但上述代码实际上输出的是 OO;

  • 第一次循环把 O 替换成了 L ,此时字符串为 LL;
  • 第二次循环,把所有的 L 都替换成了 O,所以输出结果为 OO。

解决方案:

首先想到的是定义一个对象存储当前的值和一个标记,替换之前先看它是否被访问过了,如果被访问过了就跳过。

还有一种方法就是拼接字符串,让 replace 方法只作用于当前字符。

最终答案

str = input()
newStr = ''
for i in str:
    num = ord(i)  # 得到ASCIIif (65 <= num <= 90):  # 如果是大写字母
        i = i.replace(i, chr(155 - num))
    newStr += i

print(newStr)

还有更简单的方法:

str = input()
newStr = ''
for i in str:
    if i.isupper():
        newStr += chr(155 - ord(i))
    else:
        newStr += i
        
print(newStr)