第二章

1获得用户输入的一个整数N,计算并输出N的32次方

常见错误:

n = input()
print(n**32)
2



---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-2-92804f3e9c14> in <module>()
      1 n = input()
----> 2 print(n**32)


TypeError: unsupported operand type(s) for ** or pow(): 'str' and 'int'

正确实例:

n = eval(input())#eval() 函数用来执行一个字符串表达式,并返回表达式的值。
print(n**32)
2
4294967296

2.获得用户输入的一段文字,将这段文字进行垂直输出:

L = input()
for i in L:
    print(i)
hello world!
h
e
l
l
o
 
w
o
r
l
d
!

3.获得用户输入的一个合法的算式,例如:3+4,并输出运算结果

print(eval(input()))
3+2
5

获得用户输入的一个小数,并输出其整数部分

num = eval(input())
print(round(num))
"""
In [14]: round(2.355, 2)
Out[14]: 2.35
round() 方法返回浮点数x的四舍五入值
但是不是简单的四舍五入,有兴趣可参考 https://www.runoob.com/w3cnote/python-round-func-note.html
"""
10.24
10

第三章

1.获得用户输入的一个整数,并输出百位及以上数字

num = eval(input())
num = num / 100
print(round(num))
#下为另一方法,实现方法很多,可以多尝试不同方法,能更好的理解
#num = input()
#print(num[:-2])
1024
10

2.获得用户输入的一个字符串,将字符串按照空格分割,然后逐行打印出来

L = input()
s = ""
for i in L:
    if i == ' ' or i == L[-1]:
        if i == L[-1]:
            s += L[-1]
        print(s)
        s = ""
    else:
        s += i
#学习下一章,将会有一个str.split(),可以根据指定字符进行分割,更方便,可以提前了解
hello world!
hello
world!

3.程序读入一个表示星期几的数字(1—7),输出对应的星期字符名称,例如2,返回星期二

num_to_days = ["星期一", "星期二",  "星期三",  "星期四",  "星期五",  "星期六",  "星期七",]
num = eval(input())
print(num_to_days[num-1])
3
星期三

4.输入五位数字,判断是否为回文数字

num = input()#可以当作字符串处理,也可以用类似判断水仙花的方法,代码会更少
for i in range(int(len(num)/2)):
    if num[i] != num[-(i+1)]:
        print("no")
        break
else:#奖励机制:循环完整执行时才会执行,下一章会讲到
    print("yes")
hello
no

5.输入一个十进制数,分别输出其二进制,八进制,十六进制字符串

num = eval(input())
print("{}的二进制数为:{:b},八进制数为:{:o},十六进制数为:{:x}".format(num,num,num,num)) #str.format(),用于控制格式
425
425的二进制数为:110101001,八进制数为:651,十六进制数为:1a9

第四章

1.输入一个年份,判断是否为闰年,闰年条件:能被4整除但不能被100整除或者能被400整除

year = eval(input())
if (year % 4 == 0 and year % 100) or year % 400 == 0:
    print("yes")
else:
    print("no")
2000
yes

2.获得两个数的最大公约数和最小公倍数,用辗转相除法

a = eval(input())
b = eval(input())
num1 = a
num2 = b
if b > a:
    (a,b) = (b,a)#交换a,b
while a%b:
    c = a % b
    a = b
    b = c
print("{}和{}的最大公约数是:{},最小公倍数为:{}".format(num1,num2,b,num1*num2/b))
8
4
8和4的最大公约数是:4,最小公倍数为:8.0

3.统计不同字符个数。用户输入一行字符,请统计数字,字母,空格,其他字符个数。

string = input()
dig = 0
alp = 0
space = 0
other = 0
for i in string:
    if i.upper() >= 'A' and i.upper() <= 'Z':
        alp += 1
    elif i >= '0' and i <= '9':
        dig += 1
    elif i == ' ':
        space += 1
    else:
        other += 1
print("{}中数字个数:{},字母个数:{},空格个数:{},其他:{}".format(string,dig,alp,space,other))
123,hello world!
123,hello world!中数字个数:3,字母个数:10,空格个数:1,其他:2

4.猜数字续。

import random
target = random.randint(1,1000)
count = 0
while True:
    try:
        guess = eval(input('请输入猜测的整数(1-1000):'))
        count += 1
        if guess > target:
            print("猜大了!")
        elif guess < target:
            print("猜小了!")
        else:
            print("猜对了!")
            break
    except:
        print("输入有误!请重新输入一个整数!")
print("此轮猜测次数为:",count)
请输入猜测的整数(1-1000):i
输入有误!请重新输入一个整数!
请输入猜测的整数(1-1000):100
猜小了!
请输入猜测的整数(1-1000):300
猜小了!
请输入猜测的整数(1-1000):800
猜小了!
请输入猜测的整数(1-1000):900
猜小了!
请输入猜测的整数(1-1000):950
猜大了!
请输入猜测的整数(1-1000):925
猜大了!
请输入猜测的整数(1-1000):910
猜大了!
请输入猜测的整数(1-1000):905
猜对了!
此轮猜测次数为: 9

5.羊车门问题

import random
x=100000
change=0
nochange=0
for i in range(1,x+1):
    guess=random.randrange(1,4)
    real=random.randrange(1,4)
    if guess==real:
        nochange=nochange+1
    else:
        change=change+1
    
print("不更改选择得到汽车的概率为{}".format(nochange/x))
print("更改选择得到汽车的概率为{}".format(change/x))
不更改选择得到汽车的概率为0.33338
更改选择得到汽车的概率为0.66662

第五章

1.实现isnum()函数,参数为一个字符串,如果字符串属于整数,浮点数,或者复数的表示,则返回True,否则False

def isnum(string):
    try:
        if isinstance(eval(string),int) or isinstance(eval(string),float) or isinstance(eval(string),complex):
            print("True")
    except:
        print("False")        
string = input('请输入一个字符串:')
isnum(string)
请输入一个字符串:1+1j
True

2.实现isprime(),参数为整数,要有有异常处理,返回True或者False

def isprime(num):
    for i in range(2,num):
        if num % i == 0:
            return False
    return True
try:
    num = eval(input('请输入一个整数:'))
    print(isprime(num))
except:
    print('请输入一个整数!')
请输入一个整数:17
True

3.编写一个函数,统计传入字符串中数字,字母,空格及其他字符个数

参考上一课第三题,写进函数。

4.编写函数,打印200以内的素数,以空格分隔

def printf():
    for num in range(1,201):
        for i in range(2,num):
            if num % i == 0:
                break
        else: print(num,end = ' ')
printf()
1 2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199

5.利用递归求第n个斐波那契数

def Fibonacci(n):
    if n <= 2:
        return 1
    else:
        return Fibonacci(n-1)+Fibonacci(n-2)
    
n = eval(input('请输入一个整数:'))
print(Fibonacci(n))
请输入一个整数:6
8

第六章

1.英文字符频率统计。编写一个程序,对给定字符串中出现的a~z字母频率进行分析,忽略大小写,采用降序方式输出。

txt = "i love three things,the sun for morning,the moon for night,and you for ever."
txt = txt.lower()
counts = dict()
for i in txt:
    counts[i] = counts.get(i,0) + 1
items = list(counts.items())#键值对以元组形式返回
items.sort(key = lambda x:x[1], reverse = True)#以元组中第二个值,即原始dict中的值为排列依据
for i in items:
    a, b = i
    print('{}出现的次数为{}'.format(a,b))
出现的次数为12
o出现的次数为8
e出现的次数为7
n出现的次数为7
r出现的次数为6
t出现的次数为5
h出现的次数为5
i出现的次数为4
g出现的次数为3
,出现的次数为3
f出现的次数为3
v出现的次数为2
s出现的次数为2
u出现的次数为2
m出现的次数为2
l出现的次数为1
a出现的次数为1
d出现的次数为1
y出现的次数为1
.出现的次数为1

2.中文字符频率统计。类比上例。

3.随机密码生成。编写程序在26个字母大小写,和九个数字组成的列表中随机生成10个八位密码。

import random
mimalist = [chr(i) for i in range(97,123)] + [chr(i) for i in range(65,91)] + [chr(i) for i in range(49,58)]
print(mimalist)
#以上为列表推导式,其实可以理解成把for 循环压扁。具体用法百度。
mima = [[mimalist[random.randint(0,60)] for i in range(8)] for j in range(10)]
for i in mima:
    print(''.join(i))#列表转字符串输出
['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', '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', '1', '2', '3', '4', '5', '6', '7', '8', '9']
CrOEta1h
a8YfBfiL
Lrz9Hpfv
CaJZvbaX
KiDgfTO2
wCOA2mS9
c795COYs
b3OdOdeY
6f22JdIG
Gn3vqHoA

4.重复元素判定。接受列表作为参数,如果一个元素出现次数不止一次,则返回True,但是不改变原列表值。

#可以重头到尾找,我这里用序列类型的count操作
def find_repeat(L):
    for i in L:
        if L.count(i) > 1:
            return True
    return False
    

L = input("请输入一个列表")
L = list(L)
print(L)
print(find_repeat(L))
print(L)
请输入一个列表ilovepython
['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']
True
['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']

5.重复元素判定。利用集合无重复性。

def find_repeat(L):
    new_L = set(L) #集合类型会自动去重
    if L  !=  new_L:
        return True
    return False

L = input("请输入一个列表")
L = list(L)
print(L)
print(find_repeat(L))
print(L)
请输入一个列表ilovepython
['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']
True
['i', 'l', 'o', 'v', 'e', 'p', 'y', 't', 'h', 'o', 'n']

第七章

1.输入一个文件和一个字符,统计该字符在文件中出现的次数。

def Count(fname, S, count):
    file = fname + '.txt'
    f = open(file, 'r', encoding='utf-8')
    txt = f.read()
    f.close()
    print(txt)
    count = txt.count(S)
    print('“{}”字符在《{}》中出现的的次数是:{}次'.format(S, fname, count))

fname = input('请输入txt文件名称:')
S = input('请输入一个字符:')
count = 0
Count(fname, S, count)
请输入txt文件名称:my
请输入一个字符:the
i love three things.
The sun,the moon,the night.
“the”字符在《my》中出现的的次数是:2次

2.假设有一个英文文本文件,编写一个程序读取其内容并将里面的大写字母变成小写字母,小写字母变成大写字母。

def transfer(fname):
    file = fname + '.txt'
    f = open(file, 'r', encoding='utf-8')
    txt = f.readlines()
    f.close()
    new_txt = []
    print(txt)
    for lines in txt:
        for i in lines:
            if i >= 'A' and i <= 'Z':
                new_txt.append(i.lower())
            elif i >= 'a' and i <= 'z':
                new_txt.append(i.upper())
            else:
                new_txt.append(i)
                
    f = open(file, 'w', encoding='utf-8')
    for lines in new_txt:
        f.writelines(lines)
    f.close()
    
fname = input('请输入txt文件名称:')
transfer(fname)
请输入txt文件名称:my
['i LOVE THREE THINGS.\n', 'tHE SUN,THE MOON,AND YOU.']