问题描述
输入样例: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 strreplace(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 += iprint(newStr)
还有更简单的方法:
str = input()newStr = ''for i in str:if i.isupper():newStr += chr(155 - ord(i))else:newStr += iprint(newStr)