day6-总结

一.recode

1.变量

变量名 = 值

变量存的是地址

2.运算符:

3.字符串

字符
获取字符
运算
相关方法

4.if

if
if-else
if-elif-else

5.for\while

for 变量 in 序列:
循环体
else:
代码段
执行过程:

while 条件语句:
循环体
else:
代码段
执行过程:

continue和break
else
"""
name = '余婷'
num1 = num2 = num3 = 10
num11, num22 = 10, 30

交换两个变量的值

a = 10
b = 20
a, b = b, a
print(a, b)

二.homework

1.numbers = 1
i = 0-19
i = 0 numbers = 12=2^1
i = 1 numbers = 2
2 = 2^2
i = 2 numbers = 222 = 2^3

i = 19 numbers = 2^20

numbers = 1
for i in range(0, 20):
numbers *= 2
print(numbers)
求2的20次方

num = 1 ~ 100
summation = 0
num = 1
while num <= 100:
if (num % 3 == 0 or num % 7 == 0) and num % 21 != 0:
summation += 1
num += 1
print(summation)
统计1~100中能被3或者7整除但是不能同时被3和7整除的数的个数

1.求1到100之间所有数的和、平均值

2.计算1-100之间能3整除的数的和
sum1 = 0
for x in range(0, 101, 3):
sum1 += x
print(sum1)

补充:sum函数是python内置函数:用来求数字序列的和
print(sum(range(101))

3.求斐波那契数列列中第n个数的值:1,1,2,3,5,8,13,21,34....
第n个数 = 第n-1个数 + 第n-2个数
pre_1 = 1 # 第n-1个数
pre_2 = 1 # 第n-2个数
current = 1 # 当前数(第n个数),当n=1或者2的时候,当前数就是1

n = 6 # 第几个数

num = 3 current=1+1= 2 pre_1,pre_2 = 2,1
num = 4 current=2+1=3 pre_1,pre_2=3,2

for num in range(3, n+1):
current = pre_1 + pre_2
pre_1,pre_2 = current, pre_1

print('第%d个数是%d' % (n, current))

4.判断101-200之间有多少个素数,并输出所有素数。
素数:除了1和它本身不能被其他的数整除 -->
1).将101-200中的每个都取出来
2).判断取出来的每个数是否是素数:判断这个数从2开始到这个数-1是有一个能够被它整除的
for num in range(101, 201):
判断这个num是否是素数
for x in range(2, num): # 如果2~num-1之间有一个能够被num整除的就说明num不是素数
if num % x == 0:
# print(num, '不是素数')
break # 只需要找到一个就可以证明num不是素数
else:
print(num, '是素数')

方法二

for num in range(101, 201, 2):
count = 0 # 存储2~num-1之间有几个能够被num整除的
for x in range(2, num):
if num % x == 0:
count += 1
break

if count == 0:
    print(num,'是素数')

4.打印出所有的⽔水仙花数,所谓⽔水仙花数是指⼀一个三位数,其各位数字⽴立⽅方和等于该数本身。
例例如:153是 ⼀一个⽔水仙花数,因为153 = 1^3 + 5^3 + 3^3
for num in range(100, 1000):
ge_wei = num % 10
shi_wei = num // 10 % 10
bai_wei = num // 100
if num == ge_wei3 + shi_wei3 + bai_wei**3:
print(num, '是水仙花数')

有⼀一分数序列列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列列的第20个分数
方案1:
当前分⼦: 上一个分数的分子加分母
当前分母:上一个分数的分子
fen_zi = 2
fen_mu = 1

n = 20
for x in range(2, n+1):
fen_zi, fen_mu = fen_zi+fen_mu, fen_zi

print('%d/%d' % (fen_zi, fen_mu))

方案2
第n个分子: 第n-1个分子+第n-2个分子
第n个分母:第n-1个分母+第n-2个分母
fen_zi_1 = 2
fen_mu_1 = 1
fen_zi_2 = 3
fen_mu_2 = 2
current_fenzi = 0
current_fenzmu = 0
n = 20
for x in range(3, n+1):
current_fenzi = fen_zi_1+fen_zi_2
current_fenzmu = fen_mu_1 + fen_mu_2
fen_zi_2, fen_mu_2, fen_zi_1, fen_mu_1 = current_fenzi, current_fenzmu, fen_zi_2, fen_mu_2

if n == 1:
print('2/1')
elif n == 2:
print('3/2')
else:
print('%d/%d' % (current_fenzi, current_fenzmu))

5.给⼀一个正整数,要求:1、求它是⼏几位数 2.逆序打印出各位数字
方案一:
n = 2378273
str_n = str(n)
print('%d有%d位' % (n, len(str_n)))
print(str_n[::-1])

方案二:
n = 1236
count = 1
while n // 10:
count += 1
n //= 10
print(count)

n = 1236
for _ in range(count):
print(n % 10, end='')
n //= 10

三.认识列表

1.什么是列表列表(list)
列表是python内置的可变并且有序的容器类数据类型(序列)
有序:说明可以通过下标获取元素
可变:指的是列表的中元素的个数,元素的值以及元素的位置可变(列表支持增删改)

2.列表的字面量: 中括号括起来,里面有多个元素,元素之间用逗号隔开
[元素1, 元素2, 元素3....]

元素: 可以是任何类型的数据;同一个列表,不同元素的类型可以不一样
"""
score = 90
list1 = [10, 20, 'abc', True, [1, 2]]
print(list1)

空列表
list2 = []
print(list2, type(list2))

用一个变量保存一个半的学生成绩
scores = [89, 78, 90, 32, 59, 99]

四.列表元素的增删改查

1.查(获取列表的元素)
"""
a.获取单个元素
列表[下标] - 获取指定下标对应的元素

列表一旦确定,列表中的每个元素都对应一个下标;
下标范围:0 ~ 列表长度-1;-1 ~ -列表长度
下标不能越界

films = ['战狼2', '肖生克的救赎', '沉默的羔羊', '蝴蝶效应', '回到未来', '变形金刚', '小羊肖恩']
print(films[2], films[-1])

print(films[10]) # IndexError: list index out of range

b.获取多个元素(切片) - 结果是列表
列表[开始下标:结束下标:步长]
列表[开始下标:结束下标]

print(films[1:5:2])
print(films[:4])
print(films[::-1])

c.遍历列表(将列表中的元素一个一个取出来)
for 变量 in 列表 -> 用变量获取列表中的元素

names = ['小明', '小花', '小红', '黄梅梅']
方法一:直接获取列表元素
for item in names:
print(item)

方法二:通过遍历下标获取列表元素
for index in range(len(names)):
print(names[index])

2.增(添加元素)

a.列表.append(元素) - 在指定的列表的最后添加指定的元素(不会产生新的列表)
"""
films = ['战狼2', '肖生克的救赎', '沉默的羔羊', '蝴蝶效应', '回到未来', '变形金刚', '小羊肖恩']
films.append('电锯惊魂')
print(films)

练习:录入学生成绩,保持到一个列表中。(录入的时候不断输入学生的成绩,直到输入'end'为止)
scores = []
score = input('请输入成绩:')
while score != 'end':
scores.append(int(score))
score = input('请输入成绩:')

print(scores, sum(scores))

b.列表.insert(下标, 元素) - 在指定的下标前插入指定的元素

films = ['海贼王', '火影忍者', '进击的巨人', '一人之下', '一拳超人']
films.insert(2, '海绵宝宝')
print(films, films[2])
films.insert(0, '死神')
print(films)

练习2: 有一个有序的数列[1, 7, 34, 67, 100]。
输入任意一个数字,插入到数列中,要求插入后数列还是从下到大排序的
例如:3 -> [1, 3, 7, 34, 67, 100]
200 -> [1,7, 34, 67, 100, 200]
0 -> [0, 1, 7, 34, 67, 100]
nums = [1, 7, 34, 67, 100]
value = int(input('请输入一个数字:')) # 输入一个数字,并且将输入的内容转换成int类型
index = 0 ~ len(nums) - 1
for index in range(len(nums)):
if nums[index] >= value:
nums.insert(index, value)
break
else:
如果没有找到一个比输入的数大的元素
nums.append(value)

print(nums)

3.删(删除列表元素)

a. del 列表[下标] - 删除列表中指定下标对应的元素
del - 关键字, 可以删除任何内容

films = ['战狼2', '肖生克的救赎', '沉默的羔羊', '蝴蝶效应', '回到未来', '变形金刚', '小羊肖恩']
del films[-2]
print(films)

b.列表.remove(元素) - 删除指定列表中指定的元素

注意:如果指定的元素在列表中有多个,只删除最前那一个

films = ['战狼2', '肖生克的救赎', '蝴蝶效应', '沉默的羔羊', '蝴蝶效应', '回到未来', '小羊肖恩']
films.remove('蝴蝶效应')
print(films)

c.
列表.pop() - 取出列表中最后一个元素
列表.pop(下标) - 取出列表中指定下标对应的元素

nums = [2, 34, 56, 7, 8, 9, 0]
del_num = nums.pop() # 将最后一个元素取出, 并且保存到变量del_num中
print(nums)
print(del_num)

del_num = nums.pop(1)
print(nums)
print(del_num)

练习:有一个列表,列中有数字和字符串两种类型的元素。要求将这个列表中的字符串全部放到另外一个列表中
例如:list1 = [1, 'ab', 303, 'hello', 89, 9, 90]
--> list1 = [1, 303, 89, 9, 90] 并且产生一个新的列表,list2 = ['ab', 'hello']
isinstance(10, int) # 判断10是否是整型

list1 = [1, 'ab', 'bbb', 'hello', 89, 9, 90]
index = 0 1
index = 1 'ab' list1 = [1, 'bbb', 'hello', 89, 9, 90]
index = 2 'hello'

list1 = [1, 'ab', 'bbb', 'hello', 89, 9, 90]
list2 = []
index = 0
while index < len(list1):
if isinstance(list1[index], str):
取出
item = list1.pop(index)
添加到新的列表中
list2.append(item)
continue

index += 1

print(list1, list2)

4.改(修改列表元素的值)

列表[下标] = 新值 - 将列表中指定下标对应的元素修改成指定的值

list1 = [1, 2, 'abc', 4]
list1[2] = 3
print(list1)

五.列表相关运算

1. +

列表1 + 列表2 - 使用两个列表中元素产生一个新的列表

list1 = [1, 2, 3]
list2 = ['a', 'b', 'c']
print(list1 + list2)
print(list1, list2)

2. *

列表 * n(正整数) - 将列表中的元素重复n次,产生一个新的列表

print(list1*3)

3. in和not in

元素 in 列表 判断指定的元素是否在指定的列表中
元素 not in 列表 判断指定的元素是否不在指定的列表中

names = ['小明', '路飞', '小花', '余婷']
if '余婷' in names:
print('恭喜,获奖了!')
else:
print('很遗憾!')

print(['小明', '路飞'] in names) # False

4.len

len(列表) - 获取列表元素的个数

names = [['小明', '路飞'], '小花', '余婷', {'a': 12, 'b': 123}, lambda x: x*2]
print(len(names))

5.list

list(数据) - 将其他的数据转换成列表

注意: 这儿的数据,只能是序列(所有的序列都能转换成列表-将序列中的元素作为列表的元素)

str1 = 'hello'
print(list(str1))

print(list(range(10, 20)))
print(list(100)) # TypeError: 'int' object is not iterable

6.max和min

max(列表) - 获取列表中元素的最大值
min(列表) - 获取列表中元素的最小值

注意:列表有要求:a. 列表中的元素的类型一样 b.元素对应的类型支持比较运算符

print(max([1, 45, 667, 3, 78, 90]))
print(min([1, 45, 667, 3, 78, 90]))
print(max(['ab', 'sk', 'zbs', '**(3']))

你可能感兴趣的:(day6-总结)