Python练习题(列表、字符串、循环)

1.字符串最后一个单词的长度

  • 题目描述:
    计算字符串最后一个单词的长度,单词以空格隔开。
  • 输入描述:
    一行字符串,非空,长度小于5000。
  • 输出描述:
    整数N,最后一个单词的长度。
  • 示例1:
    输入:hello world
    输出:5
#!/usr/bin/env python
#coding:utf-8

s = raw_input("请输入一行字符串:")
s1 = s.split()
print len(s1[-1])

2. 计算字符个数

  • 题目描述:
    写出一个程序,接受一个有字母和数字以及空格组成的字符串,和一个字符,然后输出输入字符串中含有该字符的个数。不区分大小写。
  • 输入描述:
    输入一个有字母和数字以及空格组成的字符串,和一个字符。
  • 输出描述:
    输出输入字符串中含有该字符的个数。
  • 示例1:
    输入:ABCDEF A
    输出:1
#!/usr/bin/env python
#coding:utf-8

s = raw_input("输入:")
s1 = s.split(" ")
s2 = s1[0].upper()
s3 = s1[-1].upper()
print s2.count(s3)

3. 简单密码破解

  • 题目描述:
    密码是我们生活中非常重要的东东,我们的那么一点不能说的秘密就全靠它了。哇哈哈. 接下来渊子要在密码之上再加一套密码,虽然简单但也安全。
    假设渊子原来一个BBS上的密码为zvbo9441987,为了方便记忆,他通过一种算法把这个密码变换成YUANzhi1987,这个密码是他的名字和出生年份,怎么忘都忘不了,而且可以明目张胆地放在显眼的地方而不被别人知道真正的密码。
    他是这么变换的,大家都知道手机上的字母: 1–1, abc–2, def–3, ghi–4, jkl–5, mno–6, pqrs–7, tuv–8 wxyz–9, 0–0,就这么简单,渊子把密码中出现的小写字母都变成对应的数字,数字和其他的符号都不做变换
  • 声明:
    密码中没有空格,而密码中出现的大写字母则变成小写之后往后移一位,如:X,先变成小写,再往后移一位,不就是y了嘛,简单吧。记住,z往后移是a哦。
  • 输入描述:
    输入包括多个测试数据。输入是一个明文,密码长度不超过100个字符,输入直到文件结尾;
  • 输出描述:
  • 输出渊子真正的密文
  • 示例1:
    输入:YUANzhi1987
    输出:zvbo9441987
  • 方法一
#!/usr/bin/env python
#coding:utf-8

p = raw_input("明文密码:")
#先把所有的小写字母转化为对应的数字
p1 = ['a','b','c']
p2 = ['d','e','f']
p3 = ['g','h','i']
p4 = ['j','k','l']
p5 = ['m','n','o']
p6 = ['p','q','r','s']
p7 = ['t','u','v']
p8 = ['w','x','y','z']

for i1 in p1:
    if i1 in p:
        p = p.replace(i1,"2")
for i2 in p2:
    if i2 in p:
        p = p.replace(i2,"3")
for i3 in p3:
    if i3 in p:
        p = p.replace(i3,"4")
for i4 in p4:
    if i4 in p:
        p = p.replace(i4,"5")
for i5 in p5:
    if i5 in p:
        p = p.replace(i5,"6")
for i6 in p6:
    if i6 in p:
        p = p.replace(i6,"7")
for i7 in p7:
    if i7 in p:
        p = p.replace(i7,"8")
for i8 in p8:
    if i8 in p:
        p = p.replace(i8,"9")
#再把所有的大写转换为小写
p = p.lower()
#然后对应往后移一位
x =['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','a']
for i in p :
    if i in x :
        p = p.replace(i,x[x.index(i)+1]) 

print "暗文密码:%s" %p
  • 方法二
#!/usr/bin/env python
#coding:utf-8

p = raw_input("明文密码:")

for i in p :
    if i == "a" or i == "b" or i == "c" :
        p = p.replace(i,"2")
    elif i == "d" or i == "e" or i == "f" :
        p = p.replace(i,"3")
    elif i == "g" or i == "h" or i == "i" :
        p = p.replace(i,"4")
    elif i == "j" or i == "k" or i == "l" :
        p = p.replace(i,"5")
    elif i == "m" or i == "n" or i == "o" :
        p = p.replace(i,"6")
    elif i == "p" or i == "q" or i == "r" or i == "s" :
        p = p.replace(i,"7")
    elif i == "t" or i == "u" or i == "v" :
        p = p.replace(i,"8")
    elif i == "w" or i == "x" or i == "y" or i == "z" :
        p = p.replace(i,"9")

p = p.lower()
x =['a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','a']
for i in p :
    if i in x :
        p = p.replace(i,x[x.index(i)+1]) 

print "暗文密码:%s" %p

4. (2017-腾讯-在线编程题)

  • 题目描述:
    给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
  • 输入描述:
    输入包括一个整数n,(3 ≤ n < 1000)
  • 输出描述:
    输出对数
  • 示例1 :
    输入:10
    输出: 2
#!/usr/bin/env python
#coding:utf-8

num = input("请输入一个正整数(3 ≤ n < 1000):")
#找出num内的所有质数,并保存在li列表中
li = []
for j in range(2,num):
    for i in range(2,num):
        i = 2
        if j%i !=0:
            i += 1
            li.append(j)
        break
#print li
#找出符合条件质数,输出总对数
p = []
count = 0
for m in li :    #m遍历列表li
    for n in li[li.index(m):]:  #n只遍历在列表li中的m及其后的质数
        if n + m == num:
            t = (m,n)     #数值存在元组
            p.append(t)   #追加到列表p中
            count += 1    #追加一次,加1
print count               #输出总对数

你可能感兴趣的:(Python)