白白的python之路--Day3

 这里仅做个人的笔记所用,内容及代码多来自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 number<answer:
        print('大一点')
    elif number>answer:
        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, ...。

a = 0
b = 1
for i in range(20):
    a, b = b, a + b
    print(a, end=' ')

例5:找出10000以内的完美数

完美数 (perfect number,又称完全数)指,它所有的真因子 (即除了自身以外的因子)和,恰好等于它自身。

for i in range(1,10000):
	num = 0
	for j in range(1,i): #j代表因子,range左闭右开,故而j<i,则因子取不到自身
		if i%j == 0: #如果余数为0,则是i的因子
			num += j #如果j是因子,则一直加
	if i == num: #完美数条件
		print(i)

例6:输出100以内的所有素数

素数指的是只能被1和自身整除的正整数(不包括1)

for i in range(2,100):
    for j in range(2,i):
        if i%j==0:
            break
    else:
        print(i)

错误经验:注意else的位置,空格位置要放对!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值