解题思路:
注意事项:
参考代码:
from itertools import permutations def f(): rst = tuple(permutations('ABCDE')) words = [] #记录A~E所说的话的内容 for i in range(5): words = words + [input().strip()] cnt = 0 for item in rst: dict = {'A':0,'B':1,'C':2,'D':3,'E':4} #A~E是按照次数讲话的 flag = 1 #筛选本次排列是否复合条件的一个标记 for i in range(5): x = dict[item[i]] #记录排在第i名的字母 alpha = words[x][0] #读取这个字母说过的话 num = int(words[x][-1]) if i in (0,2,4): #如果说话人的名词在奇数名,因为数组下标以0开头,所以此处为(0,2,4) if words[x][1] == '=': if item.index(alpha)+1 == num: flag = 0 break elif words[x][1] == '!': if item.index(alpha)+1 != num: flag = 0 break elif words[x][1] == '>' and words[x][2] != '=': if item.index(alpha)+1 > num: flag = 0 break elif words[x][1] == '<' and words[x][2] != '=': if item.index(alpha)+1 < num: flag = 0 break elif words[x][1:3] == '>=': if item.index(alpha)+1 >= num: flag = 0 break elif words[x][1:3] == '<=': if item.index(alpha)+1 <= num: flag = 0 break else: if words[x][1] == '=': if item.index(alpha)+1 != num: flag = 0 break elif words[x][1] == '!': if item.index(alpha)+1 == num: flag = 0 break elif words[x][1] == '>' and words[x][2] != '=': if item.index(alpha)+1 <= num: flag = 0 break elif words[x][1] == '<' and words[x][2] != '=': if item.index(alpha)+1 >= num: flag = 0 break elif words[x][1:3] == '>=': if item.index(alpha)+1 < num: flag = 0 break elif words[x][1:3] == '<=': if item.index(alpha)+1 > num: flag = 0 break if flag: print(''.join(item)) cnt = cnt + 1 print(cnt) if __name__ == '__main__': f()
0.0分
1 人评分
数组输出 (C语言代码)--此题的题目描述有问题浏览:1817 |
淘淘的名单 (C语言代码)浏览:1104 |
WU-输出正反三角形 (C++代码)浏览:1019 |
【偶数求和】 (C语言代码)浏览:431 |
Tom数 (C语言代码)浏览:725 |
DNA (C语言代码)浏览:741 |
青年歌手大奖赛_评委会打分 (C语言代码)浏览:2149 |
生日日数 (C语言代码)浏览:1502 |
整除的尾数 (C语言代码)浏览:814 |
班级人数 (C语言代码)浏览:926 |