python练习3

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

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

输入描述: 一行字符串,非空,长度小于5000。
输出描述: 整数N,最后一个单词的长度。

示例1:
    输入:hello world
    输出:5
代码如下:
#!/usr/bin/env python
#coding:utf-8
s=raw_input("请输入英文句子:")
s=s.split()
print len(s[-1])




# 2. 计算字符个数

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

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

示例1:
    输入:ABCDEF A
    输出:1

#!/usr/bin/env python
#coding:utf-8

s1=raw_input("请输入一个字符串:")
s2=raw_input("请输入一个字符:")
print s1.lower().count(s2.lower())









# 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
li=[]
s=raw_input("请输入明文:")
for i in s:
    if i.isdigit():
        li.append(i)
    elif i=="Z":
        n="a"
        li.append(n)
    elif i.isupper():
        i=i.lower()
        n=chr(ord(i)+1)
        li.append(n)
    elif i.lower():
        if i in("abc"):
            n=1
        if i in("def"):
            n=2
        if i in("ghi"):
            n=4
        if i in("jkl"):
            n=5
        if i in("mno"):
            n=6
        if i in("pqrs"):
            n=7
        if i in("tuv"):
            n=8
        if i in("wxyz"):
            n=9
        li.append(n)
for j in li:

    print j,





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

- 题目描述:

给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输
入值小于1000。
如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7))

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

- 输出描述:
输出对数

- 示例1 :

```
输入:
    10
输出:
    2

```

代码如下:

#!/usr/bin/env python
#coding:utf-8
n=input("num:")
def is_prime(x):
    if x==1:
        return False
    else:
        for i in range(2,x):
            if x%i==0:
                return False
        else:
            return True
prime_list =filter(is_prime,range(1,n))
count = 0
for i in prime_list:
    if is_prime(n-i) and i<=n-i:
        print(i,n-i)
        count +=1
print count



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值