这里仅做个人的笔记所用,内容及代码多来自GitHub骆昊大神的100天课程,下附链接,侵删~
GitHub - jackfrued/Python-100-Days: Python - 100天从新手到大师
一、循环结构(1)for-in循环:明确知道迭代次数或者对容器进行迭代
例1:用for循环实现1~100求和
- range(101):可以用来产生0到100范围的整数,需要注意的是取不到101。
- range(1, 101):可以用来产生1到100范围的整数,相当于前面是闭区间后面是开区间。
- range(1, 101, 2):可以用来产生1到100的奇数,其中2是步长,即每次数值递增的值。
- range(100, 0, -2):可以用来产生100到1的偶数,其中-2是步长,即每次数字递减的值。
sum=0 for x in range(101): sum+=x print(sum)
错误经验:for后面也要加冒号
例2.1:利用循环结构对1~100之间偶数求和
sum=0 for x in range(2,101,2): sum+=x print(sum)
例2.2:利用分支结构对1~100之间偶数求和
sum=0 for x in range(1,101): if x%2==0: sum += x print(sum)
错误经验:IndentationError: expected an indented block(在语句前该打空格打空格,不然运行不出来,比如在sum+=x前一定要有空格)
(2)while循环:不知道具体循环次数
例1:猜数字游戏
猜数字游戏的规则是:计算机出一个1到100之间的随机数,玩家输入自己猜的数字,计算机给出对应的提示信息(大一点、小一点或猜对了),如果玩家猜中了数字,计算机提示用户一共猜了多少次,游戏结束,否则游戏继续。
import random answer = random.randint(1,100) counter=0 while True: counter+=1 number=int(input('输入:')) if numberanswer: print('小一点') else: print('恭喜你猜对了!') break print('你共猜了%d次' % counter) if counter>7: print('你的智商余额明显不足呀')
例2:循环结构嵌套,输出九九乘法表
for i in range(1,10): for j in range(1,10): print('%d*%d=%d' % (i,j,i*j),end='t') #在结尾加换行 print()
练习:
(1)输入一个正整数判断是不是素数
-
质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数)。
from math import sqrt #math是python里的一个模型,包含很多变量和函数,sqrt是其中一个 num = int(input('请输入一个正整数:')) end = int(sqrt(num)) is_prime=True for x in range(2,end+1): if num % x==0: is_prime = False break if is_prime and num !=1: print('%d是素数' % num) else: print('%d不是素数' % num)
经验:这段代码还是要进行复习!!!
(2)输入两个正整数,计算它们的最大公约数和最小公倍数
- 两个数的最大公约数是两个数的公共因子中最大的那个数;两个数的最小公倍数则是能够同时被两个数整除的最小的那个数。
x = int(input('x = ')) y = int(input('y = ')) # 如果x大于y就交换x和y的值 if x > y: # 通过下面的 *** 作将y的值赋给x, 将x的值赋给y x, y = y, x # 从两个数中较的数开始做递减的循环 for factor in range(x, 0, -1): #找到x,y中的最小数之后,从最小数后依次递减,目的是求因子 if x % factor == 0 and y % factor == 0: print('%d和%d的最大公约数是%d' % (x, y, factor)) print('%d和%d的最小公倍数是%d' % (x, y, x * y // factor)) break
注意://运算符的意思是取整除-返回商的整数部分(向下取整),如: 9//2 得 4
(3)打印如下所示的三角形图案
row = int(input('请输入行数: ')) for i in range(row): for _ in range(i + 1): print('*', end='') print() for i in range(row): for j in range(row): if j < row - i - 1: print(' ', end='') else: print('*', end='') print() for i in range(row): for _ in range(row - i - 1): print(' ', end='') for _ in range(2 * i + 1): print('*', end='') print()
说实话,这个俺没学会!
二、构造程序逻辑例1:寻找水仙花数
水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯特朗数,它是一个3位数,该数字每个位上数字的立方之和正好等于它本身,例如:$1^3 + 5^3+ 3^3=153$。
for num in range(100,1000): low=num%10 mid=(num-low)//10%10 high=num//100 if num==low**3+mid**3+high**3: print(num)
错误经验:记住=是赋值,==才是比较!!!!
例2:百钱百鸡
公鸡5元一只,母鸡3元一只,小鸡1元三只,用100块钱买一百只鸡,问公鸡、母鸡、小鸡各有多少只?
for x in range(0,20): for y in range(0,33): z=100-x-y if 5*x+3*y+z/3==100: print('公鸡%d只,母鸡%d只,小鸡%d只' % (x,y,z))
例3:CRAPS赌博游戏
CRAPS又称花旗骰,是美国拉斯维加斯非常受欢迎的一种的桌上赌博游戏。该游戏使用两粒骰子,玩家通过摇两粒骰子获得点数进行游戏。简单的规则是:玩家第一次摇骰子如果摇出了7点或11点,玩家胜;玩家第一次如果摇出2点、3点或12点,庄家胜;其他点数玩家继续摇骰子,如果玩家摇出了7点,庄家胜;如果玩家摇出了第一次摇的点数,玩家胜;其他点数,玩家继续要骰子,直到分出胜负。
from random import randint money = 1000 while money > 0: print('你的总资产为:', money) needs_go_on = False while True: debt = int(input('请下注: ')) if 0 < debt <= money: break first = randint(1, 6) + randint(1, 6) print('玩家摇出了%d点' % first) if first == 7 or first == 11: print('玩家胜!') money += debt elif first == 2 or first == 3 or first == 12: print('庄家胜!') money -= debt else: needs_go_on = True while needs_go_on: needs_go_on = False current = randint(1, 6) + randint(1, 6) print('玩家摇出了%d点' % current) if current == 7: print('庄家胜') money -= debt elif current == first: print('玩家胜') money += debt else: needs_go_on = True print('你破产了, 游戏结束!')
例4:生成斐波那契数列的前20个数
斐波那契数列的特点是数列的前两个数都是1,从第三个数开始,每个数都是它前面两个数的和,形如:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, ...。
例5:找出10000以内的完美数
斐波那契数列的特点是数列的前两个数都是1,从第三个数开始,每个数都是它前面两个数的和,形如:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, ...。
例5:输出100以内的所有素数
素数指的是只能被1和自身整除的正整数(不包括1)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)