python练习(一)

这篇博客主要针对Python初学者,通过一系列练习来探讨字符串的基本操作,包括创建、拼接、查找、替换和分割等。通过这些实践,读者可以深入理解Python字符串的特性和用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#配置文件恢复
"""输入描述:
多行字符串,每行字符串一条命令
输出描述:
执行结果,每条命令输出一行"""
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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值