#配置文件恢复
"""输入描述:
多行字符串,每行字符串一条命令
输出描述:
执行结果,每条命令输出一行"""
while 1:
try:
s = input()
if s in 'reset':
print ('reset what')
elif s in 'reset board':
print ('board fault')
elif s in 'board add':
print ('where to add')
elif s in 'board delete':
print ('no board at all')
elif s in 'reboot backplane':
print ('impossible')
elif s in 'backplane abort':
print ('install first')
else:
print ('unknown command')
except:
break
#dna序列
"""输入描述:
输入一个string型基因序列,和int型子串的长度
输出描述:
找出GC比例最高的子串,如果有多个输出第一个的子串"""
"""
AACTGTGCACGACCTGA
5
GCACG
"""
#一个字符串有多少个指定个数的子串,字符串长度为len(s),子串的长度为n,那么有len(s)-n+1个子串
#思路:首先知道要比较多少个子串,根据字符串长度s和数字n,需要比较len(s)-n+1个子串,
#获得每个子串的G和C字符的个数
#逐个进行比较,如果新的子串的GC个数大于之前子串的个数,则记下新的子串的首位字母的下标
#直到找到符合要求的子串
#找到第一个GC比例最高的子串
while True:
try:
s = input()
#指定子串的长度
n = int(input())
gc = 0
index = 0
#需要比较的子串数为len(s)-n+1,从第一个开始进行比较,第一个子串首字母的下标为0
for i in range(len(s)-n+1): #i为子串的首字母的下标
#统计子串中的G和C的个数之和
number = s.count("G",i,i+n) + s.count("C",i,i+n)
#对前后子串的GC比例进行比较,留下GC比例较大的子串,并记下该子串的位置
if gc < number:
gc = number
#获得GC比例最高的第一个子串的位置
index = i
#获得GC比例最高的第一个子串
print(s[index:index+n])
except:
break
#只出现一次的字符
""题目描述
找出字符串中第一个只出现一次的字符
输入描述:
输入几个非空字符串
输出描述:
输出第一个只出现一次的字符,如果不存在输出 - 1
asdfasdfo
aabb
o
-1
"""
#思路:遍历字符串中的字符,如果元素出现了一次,找到了该元素,停止遍历;如果没有
#找到符合要求的字符,打印-1提示信息
while True:
try:
s=input()
#for 循环的作用是遍历字符串中的元素,找到第一个只出现一次的元素
for i in s: #414141421
if s.count(i)==1:
print(i)
#只找第一个,找到了就退出for循环
break
# 用到了for else,此处的作用是当在字符串中没有找到符合要求的元素,打印-1
else:
print("-1")
except:
break
#整数加法
"""
题目描述
输入两个用字符串表示的整数,求它们所表示的数之和。
字符串的长度不超过10000。
本题含有多组样例输入。
输入描述:
输入两个字符串。保证字符串只含有'0'~'9'字符
输出描述:
输出求和后的结果
"""
while True:
try:
x1 = int(input())
x2 = int(input())
print(x1+x2)
except:
break
python练习(一)
最新推荐文章于 2022-04-29 11:05:16 发布