您的位置:首页 > 编程语言 > Python开发

python作业周末班0401

2018-04-04 21:38 751 查看

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

题目描述:计算字符串最后一个单词的长度,单词以空格隔开。

输入描述: 一行字符串,非空,长度小于5000。

输出描述: 整数N,最后一个单词的长度。

示例1:

输入:hello world

输出:5

答案:

a=raw_input("请输入字符串:")

b = a.split(' ')

c=b.pop()

print len(c)


2. 计算字符个数

题目描述: 写出一个程序,接受一个有字母和数字以及空格组成的字符串,和一个字符,然后输出输入字符串中含有该字符的个数。不区分大小写。

输入描述: 输入一个有字母和数字以及空格组成的字符串,和一个字符。

输出描述:输出输入字符串中含有该字符的个数。

示例1:

输入:ABCDEF A

输出:1

答案:

a=raw_input("请输入一串字符:").upper()
b=raw_input("请输入一个字符:").upper()
print a.count(b)


3.# 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

答案:
key=raw_input("请输入明文密码:")

k1=['a','b','c']

k2=['d','e','f']

k3=['g','h','i']

k4=['j','k','l']

k5=['m','n','o']

k6=['p','q','r','s']

k7=['t','u','v']

k8=['w','x','y','z']

for i1 in k1:

if i1 in key:

key=key.replace(i1,"2")

for i2 in k2:

if i2 in key:

key=key.replace(i2,"3")

for i3 in k3:

if i3 in key:

key=key.replace(i3,"4")

for i4 in k4:

if i4 in key:

key=key.replace(i4,"5")

for i5 in k5:

if i5 in key:

key=key.replace(i5,"6")

for i6 in k6:

if i6 in key:

key=key.replace(i6,"7")

for i7 in k7:

if i7 in key:

key=key.replace(i7,"8")

for i8 in k8:

if i8 in key:

key=key.replace(i8,"9")

key=key.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 key:

if i in x:

key=key.replace(i,x[x.index(i)+1])

print "the key is :%s" %key


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

题目描述:

给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输

入值小于1000。

如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))

输入描述:

输入包括一个整数n,(3 ≤ n < 1000)

输出描述:

输出对数

示例1 :

输入:
10
输出:
2


答案:

def isPrime(num):
if num ==2:return True
if num <=1 or num%2==0:return False
for i in range(3,num,2):
if num %i==0:
return False
else:
return True

n= input("请输入一个值:")
prims_li=[num for num in range(1,n+1)if isPrime(num)]
count=0
for i in prims_li:
if n-i in prims_li and i<=n-i:
print(i,n-i)
count +=1
print count
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: