210122课业整理

本文详细介绍了Python中的if多分支、嵌套循环、for和while循环、位运算等概念,并通过实例解析了相关作业,包括判断素数、计算累加值、输出特定数列等内容。此外,还涉及位运算在判断奇偶性和快速乘法中的应用。
摘要由CSDN通过智能技术生成

210122课业整理

一、前情回顾

1、if 多分支结构

写法:

if 条件语句1:
代码段1
elif 条件语句2:
代码段2
elif 条件语句3:
代码段3

else:
代码段n

2、if 嵌套
num = 8
if num % 2 == 0:
    print('偶数')
    if num % 4 == 0:
        print('4的倍数')
else:
    print('奇数')
3、for循环

写法:

for 变量 in 序列:
循环体

4、range函数

range(n) --> 0~n-1
range(m, n) --> m~n-1
range(m, n, step) --> step代表步长,m需要加的值
与for循环搭配使用

for x in range(5):
	print('x:', x)
5、while 循环

写法:

while 条件语句:
循环体

循环关键字

continue 结束本次循环

break 结束整个循环

else:

求和的套路

num = [10, 34, 56, 2]
sum1 = 0
for x in num:
    sum1 += x
print(sum1)
6、昨日作业解析

1.根据输入的成绩的范围打印及格或者不及格

grade = float(input('输入成绩:'))
if grade >= 60:
    print('及格')
else:
    print('不及格')
# 输入成绩:44
#不及格

2.根据输入的年纪范围打印成年或者未成年

如果年龄不在正常范围内(0~150)打印这不是人!

age = float(input('请输入年龄'))   # 请输入年龄-1
if 150 >= age >= 18:
    print('成年')
elif 0 < age < 18:
    print('未成年')
if age <= 0 or age > 150:
    print('这不是人')
# 这不是人

方法二 更简单

if age <= 0 or age > 150:
    print('这不是人')
elif age < 18:
    print('未成年')
else:
    print('成年')

3.输入两个整数a和b,若a - b的结果为奇数,则输出该结果,

否则输出提示信息a - b的结果不是奇数

a = int(input('输入数字a:'))
b = int(input('输入数字b:'))
if (a - b) % 2 != 0:
    print(a - b)
else:
    print('a-b的结果不是奇数')

# 输入数字a:10
# 输入数字b:4
#a-b的结果不是奇数

4.使用for和while循环输出0~100内所有3的倍数。

# for 循环
count = 0
for x in range(0, 99, 3):
    count += 3
    print(count)
# while 循环
num = 0
while True:
    print(num)
    num += 3
    if num > 100:
        break

5.使用for和while循环输出0~100内所有的偶数。

# for循环,step==2
for num in range(0, 101, 2):
    print(num)
# while循环
num = 0
while True:
    print(num)
    num += 2
    if num > 100:
        break

6.使用循环计算1 * 2 * 3 * 4 * ... * 10的结果。

result = 1
for num in range(1, 11):
    result *= num
print(result)

7.统计100以内个位数是2并且能够被3整除的数的个数。

count = 0
for num in range(2, 101, 10):
    if num % 3 == 0
        count += 1
print(count)

8.输入任意一个正整数,求他是几位数?

# 不使用字符串,解法
# 执行过程:
num = int(input('请输入一个正整数:'))   # 第一步
# 运算逻辑:看整除10多少次以后会变成0
count = 1   # 第二步 位数没有0,至少一位数,
# 第三步,while循环
while True:
    num //= 10
    count += 1
    if num == 0:
        break
print(count)
# 使用字符串解法  后期学习
num = 2344
len(str(2344))
print(len(str(num)))

9.打印出所有的水仙花数, 所谓水仙花数是指一个三位数,

其各位数字⽴方和等于该数本身。例如: 153是⼀个⽔仙花数, 因为

#1³ + 5³ + 3³ 等于153。

# 执行过程
for num in range(100, 1000):
    g = num % 10   # 对个位数取余
    s = num // 10 % 10    # 对十位数取余
    b = num // 100     # 对百位数取余
    if g ** 3 + s ** 3 + b ** 3 == num:
        print('水仙花数:', num)

10.判断指定的数是否是素数

(素数就是质数,即除了1和它本身以外不能被其他的数整除的数)

# 执行过程
num = int(input('请输入一个整数:'))
for x in range(2, num):
    if num % x == 0:
        print(num, '不是素数')
        break
else:
    print(num, '是素数')

# 方法二,更优化
num = int(input('请输入一个整数:'))
for x in range(2, int(num**(0.5+1))):
    if num % x == 0:
        print(num, '不是素数')
        break
else:
        print(num, '是素数')

练习:判断指定数是否是偶数

num = 3
if not num & 1:    # 位运算符&  能使程序更优化
    print('偶数')

2.求斐波那契数列列中第n个数的值: 1,1,2,3,5,8,13,21,34…

(这儿的n可以是任意正整数,可以通过输入来确定)

n = int(input('请输入一个正整数:'))
num1 = 1
num2 = 1
for _ in range(n - 3):   # _ 下划线代表此变量不参与运算
	next=num1+num2
	num1,num2=num2,next
	num1, num2  = num2, num1 + num2
print(num1 + num2)

3.输出9 * 9 口诀。 程序分析:分行与列考虑,共9行9列,i控制行,j控制列。

for line in range(1, 10):
    for col in range(1, line + 1):
        print(col, 'x', line, '=', col * line, end=' ; ')
    print()
# end=';'   的作用是为了换行

4.这是经典的"百马百担"问题,有一百匹马,驮一百担货,大马驮3担,

中马驮2担,两只小马驮1担,问有大,中,小马各几匹?(可以直接使用穷举法)

for big in range(0, 100 // 3 + 1):
    for mid in range(0, 100 // 2 + 1):
        for small in range(0, 101, 2):
            if big+mid+small == 100 and big*3+mid*2+small/2 == 100:
                print('大马:', big, '中马:', mid, '小马:', small)

二、位运算

计算机直接能存储的数据只有数字

以二进制 方式存储 0101010101

rgb值 计算机三原色:红绿蓝 0~255

数字再以二进制补码的形式存储

1.进制

**10进制:**12 932 23 (数值范围0~9)

Python默认10进制

**2进制:**0101 11 10101010 (0~1)

num = 0b10 # 二进制要加前缀 0b

**8进制:**765 01045 (0~7)

num1 = 0o10 # 8进制前缀 0o

**16进制:**123ade fff110 (09和af)

num2 = 0x123a # 16进制前缀 0x

bin() 转二进制

oct() 转8进制

hex() 转16进制

2.二进制的原码、反码、补码

**原码:**最高位表示符号位,后面是数的真值(数字的绝对值的二进制)

0表示正 1表示负

正数的原码,反码,补码一样的

**反码:**10(反码)0 0001010

-10(反码)1 1110101

**补码:**反码加1

0+00 0+11 (1+1==0,进一位)

-10(补码)1 1110110

3.位运算:直接对计算机内存空间进行操作,快捷且没有额外消耗

&(按位与)

print(5 & 2)

应用1,快速判断整数的奇偶性

所有偶数在存储时最低位都是0,奇数存储时最低位都为1

数字与1 运算 数字&1

print(4 & 1)
print(5 & 1)

num4 = 43
if num4 & 1 == 1:
    print('奇数')
else:
    print('偶数')

| 按位或

^ 异或

~ 取反

<< 左移

**应用:**整数快速乘2的n次方

print(3 << 1)   # 3**2==6
print(3 << 2)   # 12

>>右移

**应用:**快速整除2的n次方

print(6 >> 1)   # 6//2==3

三、今日作业

  1. 判断101-200之间有多少个素数,并输出所有素数。

    for x in range(101, 201):
        for y in range(2, x):  
        #素数就是质数,即除了1和它本身以外不能被其他的数整除的数
            if x % y == 0:
            #x=[101,200)   x对y取余
                break
        else:
            print(x)
    
  2. 求整数1~100的累加值,但要求跳过所有个位为3的数。

  3. 有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数

  4. 写程序计算 n 的阶乘 n! 的结果

  5. 求1+2!+3!+…+20!的和

  6. 写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)

    例如:a为3, n为5的时候: 3 + 33 + 333 + 3333 + 33333

  7. 控制台输出三角形

    a.根据n的值的不同,输出相应的形状
    n = 5时             n = 4
    *****               ****
    ****                ***
    ***                 **
    **                  *
    *
    
    b.根据n的值的不同,输出相应的形状(n为奇数)
    n = 5               n = 7
      *                    *
     ***                  ***
    *****                *****
                        *******
    
    c. 根据n的值的不同,输出相应的形状
    n = 4
       1
      121
     12321
    1234321
    
    n = 5
        1
       121
      12321
     1234321
    123454321
    
  8. 小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?

  9. 一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

  10. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

  11. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。

  12. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值

  13. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。

  14. 本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。

  15. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)

  16. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值