问题描述
输入样例:
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) # 得到ASCII码
if (65 <= num <= 90): # 如果是大写字母
str = str.replace(i, chr(155 - num))
print(str)
遇到的问题:
在思路二中,我之前的代码是这样的:
str = input()
def replace(str):
for i in str:
num = ord(i) # 得到ASCII码
if (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) # 得到ASCII码
if (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) # 得到ASCII码
if (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)
python实现26个英文字母按规则输出
import string
n=eval(input())
s=string.ascii_uppercase
for i in s:
print(i,end='')
if (s.find(i)+1)%n==0:
print()
以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。