1.字符串最后一个单词的长度
题目描述:计算字符串最后一个单词的长度,单词以空格隔开。
输入描述: 一行字符串,非空,长度小于5000。
输出描述: 整数N,最后一个单词的长度。
示例1:
输入:hello world
输出:5
#!/usr/bin/env python
#coding:utf-8
"""
计算字符串最后一个单词的长度,单词以空格隔开
#用try except 处理程序异常!
"""
while 1:
try:
l = raw_input()
if len(l) == 0:
print "请正确输入字符串!"
break
if len(l)>5000:
l=l[:5000]
wordList=l.split()
print len(wordList[-1])
except:
break
2. 计算字符个数
题目描述: 写出一个程序,接受一个有字母和数字以及空格组成的字符串,和一个字符,然后输出输入字符串中含有该字符的个数。不区分大小写。
输入描述: 输入一个有字母和数字以及空格组成的字符串,和一个字符。
输出描述:输出输入字符串中含有该字符的个数。
示例1:
输入:ABCDEF A
输出:1
#!/usr/bin/env python
#coding:utf-8
"""
写出一个程序,接受一个有字母和数字以及空格组成的字符串,
和一个字符,然后输出输入字符串中含有该字符的个数,不区分大小写。
"""
s = raw_input()
ch = raw_input()
num = 0
s = s.lower() if isinstance(s, str) else s #isinstance 判断是否为字符串
ch = ch.lower() if isinstance(ch, str) else ch
for i in s:
if ch == i:
num +=1
print num
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
shuzi = '0123456789'
zimu = 'zxcvbnmasdfghjklqwertyuiop'
zimu1 = 'ZXCVBNMASDFGHJKLQWERTYUIOP'
s = raw_input ("请输入密码:")
l = list(s)
for i in range (len(l)):
if l[i] in shuzi:
continue
elif l[i] in zimu:
n = (ord(l[i]) - 91) / 3
if n > 9:
n = '9'
else:
n = '4'
l[i] = n
elif l[i] in zimu1:
s1 = chr(ord(l[i]) + 33)
l[i] = s1
else:
print "输入非法字符:"
print ''.join(l)
4. (2017-腾讯-在线编程题)
- 题目描述:
给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))
输入描述:
输入包括一个整数n,(3 ≤ n < 1000)输出描述:
输出对数示例1 :
输入:
10
输出:
2
#!/usr/bin/env python
#coding:utf-8
def panduanzhishu(x):
if x <= 1:
return False
else:
min = 2
while min < x:
if x % min == 0:
return False
min += 1
else:
return True
n=input("请输入:")
l=[]
for i in range(3,n):
if panduanzhishu(i):
l.append(i)
count=0
for i in range(0,len(l)):
x=l.pop()
y=n-x
if x==y:
count+=1
elif l.count(y) > 0:
count+=1
print count