擅长:python、mysql、java
<p>见下文<br/>
我们的想法是使用2个DICT来支持从低到高&;从上到下</p>
<pre><code>l2u = {'a': 'A', 'b': 'B', 'c': 'C', 'd': 'D', 'e': 'E', 'f': 'F', 'g': 'G', 'h': 'H', 'i': 'I', 'j': 'J', 'k': 'K', 'l': 'L', 'm': 'M', 'n': 'N', 'o': 'O', 'p': 'P', 'q': 'Q', 'r': 'R', 's': 'S', 't': 'T', 'u': 'U', 'v': 'V', 'w': 'W', 'x': 'X', 'y': 'Y', 'z': 'Z'}
u2l = {'A': 'a', 'B': 'b', 'C': 'c', 'D': 'd', 'E': 'e', 'F': 'f', 'G': 'g', 'H': 'h', 'I': 'i', 'J': 'j', 'K': 'k', 'L': 'l', 'M': 'm', 'N': 'n', 'O': 'o', 'P': 'p', 'Q': 'q', 'R': 'r', 'S': 's', 'T': 't', 'U': 'u', 'V': 'v', 'W': 'w', 'X': 'x', 'Y': 'y', 'Z': 'z'}
def get_str_versions(string):
result = []
for x in range(len(string)):
if string[x] in l2u:
result.append(string[0:x] + l2u[string[x]] + string[x+1:])
else:
result.append(string[0:x] + u2l[string[x]] + string[x+1:])
return result
print(get_str_versions('Hello'))
</code></pre>
<p>输出</p>
<pre><code>['hello', 'HEllo', 'HeLlo', 'HelLo', 'HellO']
</code></pre>