题目描述:有一种特殊的英文单词,它的相邻字母对之间的“距离”不断增加。如单词subway,它的相邻字母对分别为 (s, u), (u, b), (b, w), (w, a), (a, y), 字母之间的距离依次为2,19,21,22,24(如a是第1个字母,y是第25个字母,a和y的距离为24)。编写函数is_special_word(word),word为输入单词字符串,如为特殊单词,返回True;否则返回False。 输入:单词 输出:如为特殊单词,返回True;否则返回False。
输入样例:subway
输出样例:True
方法1:
def is_special_word(word):
# 定义一个空的列表,用于存储字母之间的距离
distances = []
# 使用for循环遍历单词的每个字母,需注意循环范围
for i in range(len(word)-1):
# 计算相邻字母的距离,并将其添加到列表distances中
distance = ord(word[i+1])-ord(word[i])
distances.append(distance)
# 使用for循环遍历列表distances,需注意循环范围
for j in range(len(distances)-1):
# 检查相邻字母距离是否按规律递增,如果有不符合的直接返回False
if distances[j]>=distances[j+1]:
return False
# 如果检查通过,即相邻字母距离按规律递增,返回True
return True
方法2:
word=list(input())
distance=[]
for i in range(len(word)-1):
dis=abs(ord(word[i+1])-ord(word[i]))
distance.append(dis)
for j in range(len(distance)-1):
if distance[j]>=distance[j+1]:
print('False')
break
else:
print('True')