python练习题之二:

python练习题之二:

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

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

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

示例1:
输入:hello world
输出:5


具体思路解法如下;

str = input("请输入一个字符串:")

str1 = str.split(" ")

a = len(str1[-1])

print ("该字符串最后一个单词长度为:%d" %(a))

实现结果:



# 2. 计算字符个数

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

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

示例1:
输入:ABCDEF A

输出:1


具体解法思路如下:

str = input("请输入一个字符串:")

zi = input("请输入你要查找的字符:")

a = 0

for i in str.upper() :
    if zi.upper() == i :
        a += 1
print ("该字符一共出现%d次" %(a))

实现结果如下:



# 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


具体解法思路如下:

set = []
str = input("请输入你要查询的密码:")

ls = len(str)
if ls > 100 :
    print ("密码过长,请输入小于100字符!")
else :
    for i in str :
        if i == ' ' :
            print ("输入格式错误,请重新输入!")
            exit(0)

        elif i.isupper() :
            if i == 'Z' :
                set.append('a')
            else :
                str1 = chr(ord(i)+33)
                set.append(str1)

        elif i.islower() :
            if i == 'w' or i == 'x' or i == 'y' or i =='z' :
                str2 = '9'
                set.append(str2)
            elif i == 't' or i == 'u' or i == 'v' :
                str3 = '8'
                set.append(str3)
            elif i =='p' or i =='q' or i == 'r' or i == 's' :
                str4 = '7'
                set.append(str4)
            elif i == 'm' or i == 'n' or i == 'o' :
                str5 = '6'
                set.append(str5)
            elif i =='j' or i == 'k' or i == 'l' :
                str6 = '5'
                set.append(str6)
            elif i == 'g' or i == 'h' or i == 'i' :
                str7 = '4'
                set.append(str7)
            elif i == 'd' or i == 'e' or i == 'f' :
                str8 = '3'
                set.append(str8)
            elif i == 'a' or i == 'b' or i == 'c' :
                str9 = '2'
                set.append(str9)

        else :
            set.append(i)

    str10 = "".join(set)
    print ("密码为%s" %(str10))

实现结果如下:


- 题目描述:

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

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

- 输出描述:
输出对数

- 示例1 :
```
输入:
    10
输出:
    2

```


具体解法思路如下:

set = []
X = 0
import math
for i in range(2,1000) :
    a = int(math.sqrt(i))
    for j in range(2,a+1) :
        if i % j == 0 :
            break
    else :
        set.append(i)

num = int(input("请输入你要查询的数字:"))
num1 = int(num / 2)
for o in set :
    if (num - o) in set :
        if o <= num1 :
            X += 1
print ("该数字有%s对质数和" %(X))

实现结果:


--end

猜你喜欢

转载自blog.csdn.net/qq_41891803/article/details/80193524
今日推荐