小易喜欢的单词具有以下特性: 1.单词每个字母都是大写字母 2.单词没有连续相等的字母 3.单词没有形如“xyxy”(这里的x,y指的都是字母,并且可以相同)这样的子序列,子序列可能不连续。 例如: 小易不喜欢”ABBA”,因为这里有两个连续的’B’ 小易不喜欢”THETXH”,因为这里包含子序列”THTH” 小易不喜欢”ABACADA”,因为这里包含子序列”AAAA” 小易喜欢”A”,”ABA”和”ABCBA”这些单词 给你一个单词,你要回答小易是否会喜欢这个单词。
输入描述: 输入为一个字符串,都由大写字母组成,长度小于100
输出描述: 如果小易喜欢输出”Likes”,不喜欢输出”Dislikes”
示例1 :
输入 AAA 输出 Dislikes 解答: #!/usr/bin/env python #coding:utf-8 """ file:.py date:2017/8/31 9:12 author: peak description: """ def Judge1(Word): if Lenth == 1: return True else: for n in range(Lenth-1): if Word[n] == Word[n+1]: return False else : return True def Judge2(Word): L = list(Word) for i in L : if L.count("i") == 1 : L.remove("i") Ls = [] for i in range(0,len(L)-1): for j in range(i+1,len(L)): Ls.append(L[i]+L[j]) if len(Ls) == len(set(Ls)): return True else: return False Word = raw_input("输入为一个字符串,都由大写字母组成,长度小于100 : ") Word=Word.upper() Lenth = len(Word) if Lenth >= 100 : print "it is longer than 100" if Judge1(Word) and Judge2(Word) : print "Likes" else : print "Dislikes"运行结果:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。 如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
输入描述: 输入包括一个整数n,(3 ≤ n < 1000)
输出描述: 输出对数
示例1 :
输入: 10 输出: 2 解答: #!/usr/bin/env python #coding:utf-8 """ file:.py date:2017/8/31 10:16 author: peak description: """ from math import sqrt Allprime=[] count = 0 def prime(n): for i in range(2,n): flg=True for j in range(2,int(sqrt(i)+1)): if i%j==0 : flg=False if flg==True : Allprime.append(i) n=input("输入包括一个整数n,(3 ≤ n < 1000) : ") prime(n) Max=Allprime[-1] for i in Allprime: for j in range(i,Max): if i+j == n: print "{} + {} = {}".format(i,j,n) count +=1 print count 运行结果:题目描述: 输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.”
输入描述: 每个测试输入包含2个字符串
输出描述: 输出删除后的字符串
示例1:
输入 They are students. aeiou 输出 Thy r stdnts. 解答: #!/usr/bin/env python #coding:utf-8 """ file:.py date:2017/9/1 14:12 author: peak description: """ Str1=raw_input("please input a string : ") Str2=raw_input("please input a string that you want to delete :") Str='' for i in Str1 : if i not in Str2 : Str += i print Str 运行结果:题目描述: 输入两个整数 n 和 m,从数列1,2,3…….n 中随意取几个数,使其和等于 m ,要求将其中所有的可能组合列出来
输入描述:
每个测试输入包含2个整数,n和m
输出描述: 按每个组合的字典序排列输出,每行输出一种组合
示例1 :
输入: 5 5 输出: 1 4 2 3 5 解答: 运行结果:18位身份证的编码规则是: 前1、2位数字表示:所在省(直辖市、自治区)的代码 第3、4位数字表示:所在地级市(自治州)的代码 第5、6位数字表示:所在区(县、自治县、县级市)的代码; 第7—14位数字表示:出生年、月、日; 第15、16位数字表示:所在地的派出所的代码; 第17位数字表示性别:奇数表示男性,偶数表示女性; 第18位数字是校检码,用来检验身份证的正确性。 用户在输入身份证的过程中经常会输入错误,为了方便用户正确输入需要在输入过程中对用户的输入按照 6+8+4 的格式进行分组,实现一个方法接收输入过程中的身份证号,返回分组后的字符
输入描述: 输入数据有多行,每一行是一个输入过程中的身份证号
输出描述: 分组后的字符串
示例1
输入: 5021 502104 198803 5021041988033084 502104198803308324 输出: 5021 502104 198803 502104 19880330 84 502104 19880330 8324 解答: #!/usr/bin/env python #coding:utf-8 """ file:.py date:2017/9/1 15:46 author: peak description: """ while True : Id=raw_input("please input the id number : " ) if len(Id) <= 6 : print Id[0:] elif 6 <len(Id)<=14 : print Id[0:6],Id[6:] elif 14<len(Id)<=18: print Id[0:6],Id[6:14],Id[14:] else: print "please input right id number!" 运行结果: