C语言基础-判断质数(素数)

YOLOX系列文章(一):先来看看论文

  返回  

day7-元组和字典

2021/7/20 20:15:52 浏览:

Python-列表、元组和字典

1.列表

1)max、min - 求最大值、最小值

# max(序列)
nums = [34, 89, 78, 56, 90, 23]
print(max(nums), min(nums))

2)sum - 求数字序列中元素的和

# sum(序列)
nums = [34, 89, 78, 56, 90, 23]
print(sum(nums))

3) sorted - 排序;不修改原序列中元素的顺序而是产生一个新的列表

# sorted(序列);sorted(序列, reverse=True)
nums = [34, 89, 78, 56, 90, 23]
new_nums = sorted(nums)
print(nums)         # [34, 89, 78, 56, 90, 23]
print(new_nums)     # [23, 34, 56, 78, 89, 90]

# 列表.sort();列表.sort(reverse=True)
nums = [34, 89, 78, 56, 90, 23]
result = nums.sort()
print(nums)     # [23, 34, 56, 78, 89, 90]
print(result)   # None

4) len - 获取序列中元素的个数

len(序列)

5) list - 列表类型转换

# list(序列)  -  所有的序列都可以转换成列表;转换的时候直接将序列中的元素转换成列表元素
print(list('abc'))      # ['a', 'b', 'c']
print(list(range(3)))   # [0, 1, 2]

# print(list(enumerate(nums)))    # [(0, 23), (1, 34), (2, 56), (3, 78), (4, 89), (5, 90)]

2.列表推导式 - 本质就是创建列表的表达式(简洁)

1) 结构一:
[表达式 for 变量 in 序列]

结构二:
[表达式 for 变量 in 序列 if 条件语句]

list1 = [10 for x in range(4)]
print(list1)        # [10, 10, 10, 10]

list2 = [x for x in range(4)]
print(list2)        # [0, 1, 2, 3]

list3 = [x * 2 + 1 for x in range(4)]
print(list3)        # [1, 3, 5, 7]

scores = [89, 67, 34, 56, 10, 90]
list4 = [x % 10 for x in scores]
print(list4)        # [9, 7, 4, 6, 0, 0]

list5 = [x >= 60 for x in scores]
print(list5)        # [True, True, False, False, False, True]

scores = [89, 67, 34, 56, 10, 90]
list6 = [x * 2 for  x in scores]
print(list6)        # [178, 134, 68, 112, 20, 180]

list7 = [10 for x in range(4) if x % 2]
print(list7)        # [10, 10]

list8 = [x for x in range(4) if x % 2]
print(list8)        # [10, 10]

scores = [89, 67, 34, 56, 10, 90]
list9 = [x for x in scores if x >= 60]
print(list9)        # [89, 67, 90]

2) 推导式的应用

应用1:让序列中所有的元素进行统一变换
[表达式 for 变量 in 序列]

应用2:将序列中满足某个条件的元素进行交换(根据某个条件是否满足做两种不同的变换)
[表达式1 if 条件语句 else 表达式2 for 变量 in 序列]

应用3:提取序列中满足某个条件的元素(提取、删除)
[表达式 for 变量 in 序列 if 条件语句]

# [89, 67, 34, 56, 10, 90]  ->  [[0, 89], [1, 67], [2, 34], [3, 56], [4, 10], [5, 90]]
nums = [89, 67, 34, 56, 10, 90]
new_nums = [[x, nums[x]] for x in range(len(nums))]
print(new_nums)

# 将nums中所有的偶数除以2
# [89, 67, 34, 56, 10, 90, 35] -> [89, 67, 17, 28, 5, 45, 35]
nums = [89, 67, 34, 56, 10, 90, 35]
new_nums = [x if x % 2 else int(x/2) for x in nums]
print(new_nums)

# 练习2:删除所有的偶数(提取所有的奇数)
# [89, 67, 34, 56, 10, 90, 35] -> [89, 67, 35]
nums = [89, 67, 34, 56, 10, 90, 35]
new_nums = [x for x in nums if x % 2 ]
print(new_nums)

3) 双目运算符:+、-、*、… 、> 、= 、and、or
单目运算符:not
三目运算符:if-else

① C/Java语言的三目运算符:

条件语句?表达式1:表达式2 - 如果条件语句成立整个运算结果是表达式1的值,否则整个运算结果是表达式2的值

② python的三目运算符

表达式1 if 条件语句 else 表达式2 - 如果条件语句成立整个运算结果是表达式1的值,否则整个运算结果是表达式2的值

age = 38
# if age >= 18:
#     a = '成年'
# else:
#     a = '未成年'
a = '成年' if age >= 18 else '未成年'
print(a)

3.元组

1)什么是元组(tuple)

元组是容器型数据类型, 将()作为容器的标志,里面多个元素逗号隔开:(元素1, 元素2, 元素3,...)
元组不可变(只能查);元组有序 - 支持下标操作
元素:和列表一样

① 空元组

t1 = ()
print(type(t1), len(t1))        # <class 'tuple'> 0

② 只有一个元素的元组 - 唯一的元素后面必须加逗号

list1 = [12]
print(list1, type(list1), len(list1))   # [12] <class 'list'> 1

t2 = (12)
print(t2, type(t2))     # 12 <class 'int'>

t3 = (12,)
print(t3, type(t3))     # (12,) <class 'tuple'>

③ 普通情况

t4 = (10, 34, 78)
print(t4)       # (10, 34, 78)

④在没有歧义的情况下,元组的小括号可以省略(直接将多个数据用逗号隔开表示的也是一个元组)

t5 = 10, 34, 78
print(t5, type(t5))     # (10, 34, 78) <class 'tuple'>

t6 = 10, 34, 78 * 2
print(t6)       # (10, 34, 156)

2) 查 - 获取元素

① 列表获取元素的方式元组都支持

nums = (23, 45, 90, 78, 6, 34)
print(nums[1], nums[-5])

print('---------------------------------')
for x in nums:
    print(x)

print('---------------------------------')
for index in range(len(nums)):
    print(index, nums[index])

print('---------------------------------')
for index, item in enumerate(nums):
    print(index, item)

print('---------------------------------')
print(nums[1:])
print(nums[::-1])

② 通过变量直接获取元组的元素1 - 让变量的个数和元组中元素的个数保持一致

point = (10, 23, 12)
x, y, z = point
print(x, y, z)      # 10 23 12

③ 通过变量直接获取元组的元素2

如果变量的个数小于元素的个数,那么必须在其中一个变量前加
取得时候先让没有变量按照位置关系获取元素,剩下的全部给带的变量(以列表的形式)
*

info = ('张三', 18, 175, 180, 90, 67, 89)
name, age, *other = info
print(name, age, other)    # 张三 18 [175, 180, 90, 67, 89]

name, *other = info
print(name, other)   # 张三 [18, 175, 180, 90, 67, 89]

name, age, *other, math = info
print(name, age, math)   # 张三 18 89
print(other)    # [175, 180, 90, 67]

x, *y, z, m = info
print(x, z, m)      # '张三' 67 89
print(y)    # [18, 175, 180, 90]

*x, y, z = info
print(y, z)
print(x)

4.字典

1)字典的作用 - 同时保存多个意义不同的数据

stu = {
    'name': '小明',
    'age': 20,
    'gender': '男',
    '体重': 60,
    'math': 89,
    '语文': 70,
    '英语': 55
}
print(stu['name'])

2)什么是字典(dict)

字典是容器型数据类型;将{}作为容器标志,里面多个键值对用逗号隔开:{键1:值1, 键2:值2, 键3:值3,…}
字典是可变的(支持增删改);字典是无序(不支持下标操作)

元素的要求:字典元素是键值对
键 - 键必须是不可变的数据(例如:数字、字符串、元组);键是唯一的;
值 - 没有要求

① 空字典:{}

d1 = {}
print(type(d1), len(d1), bool(d1))      # <class 'dict'> 0 False

② 键是不可变的数据

d2 = {1: 10, 'a': 20, (10, 20): 30}
print(d2)

# d3 = {1: 10, 'a': 20, [10, 20]: 30}     # 报错

③ 键是唯一的

d4 = {'a': 10, 'b': 20, 'c': 30, 'b': 40}
print(d4)   # {'a': 10, 'b': 40, 'c': 30}

④ 字典是无序的

print({'a': 10, 'b': 20} == {'b': 20, 'a': 10})     # True
print([10, 20] == [20, 10])     # False

3) 字典的增删改查

①查 - 获取字典的值
a.获取单个值
字典[键] - 获取字典中指定键对应的值,如果键不存在程序报错;
字典.get(键)/ 字典.get(键, 默认值) - 获取字典中指定键对应的值,如果键不存在返回None或者默认值

dog = {'name': '财财', 'age': 3, 'breed': '土狗', 'gender': '母狗', 'color': '黑色'}
print(dog['name'])
print(dog['gender'])

print(dog.get('name'))

# print(dog['height'])          # KeyError: 'height'
# print(dog.get('height'))      # None
print(dog.get('height', 0))     # 0

b.遍历
通过for循环遍历字典的时候,循环变量依次取到的是字典的键
for 键 in 字典:
循环

print('--------------------------------------------')
for key in dog:
    print(key, dog[key])

print('--------------------------------------------')

4)实际应用中的字典和列表

# 定义一个变量保存一个班级信息
class1 = {
    'name': 'python2104',
    'address': '23教',
    'lecturer': {'name': '余婷', 'age': 18, 'QQ': '726550822'},
    'leader': {'name': '舒玲', 'age': 18, 'QQ': '2343844', 'tel': '110'},
    'students': [
        {'name': 'stu1', 'school': '清华大学', 'tel': '1123', 'linkman': {'name': '张三', 'tel': '923'}},
        {'name': 'stu2', 'school': '攀枝花学院', 'tel': '8999', 'linkman': {'name': '李四', 'tel': '902'}},
        {'name': 'stu3', 'school': '成都理工大学', 'tel': '678', 'linkman': {'name': '小明', 'tel': '1123'}},
        {'name': 'stu4', 'school': '四川大学', 'tel': '9900', 'linkman': {'name': '小花', 'tel': '782'}},
        {'name': 'stu5', 'school': '西南交大', 'tel': '665', 'linkman': {'name': '老王', 'tel': '009'}}
    ]

}
# 1)获取班级名称
print(class1['name'])
# 2)获取讲师QQ
print(class1['lecturer']['QQ'])
# 3)获取所有学生的名字和学校
for stu in class1['students']:
    print(stu['name'], stu['school'])
# 4)获取所有学生的联系人的电话
for stu in class1['students']:
    print(stu['linkman']['tel'])

作业:

1.创建一个列表,列表中有10个舒宗, 保证列表中元素的顺序,对列表进行排重,并对列表使用进行降序排序

例如:随机生成了[70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
		--- 去重之后 [70, 88, 91, 107, 234, 177, 282, 197]
  	---- 降序排序 [282, 234, 197, 177, 107, 91, 88, 70]
list1 = [70, 88, 91, 70, 107, 234, 91, 177, 282, 197]
list2 = []
for item in list1:
    if item not in list2:
        list2.append(item)
print('去重后:', list2)
list2.sort(reverse=True)
print('降序排序:', list2)

2.利用列表推导式, 完成以下需求

a. 生成一个存放1-100中个位数为3的数据列表

结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
print([x for x in range(3, 100, 10)])

b. 利用列表推导式将列表中的整数提取出来

例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
list1 = [True, 17, "hello", "bye", 98, 34, 21]
print([x for x in list1 if type(x) == int])

c.利用列表推导式 存放指定列表中字符串的长度

例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
list1 = ["good", "nice", "see you", "bye"]
print([len(x) for x in list1])

4.已经一个班级字典如下:

class1 = {
    'name': 'python2104',
    'address': '23教',
    'lecturer': {'name': '余婷', 'age': 18, 'QQ': '726550822'},
    'leader': {'name': '舒玲', 'age': 18, 'QQ': '2343844', 'tel': '110'},
    'students': [
        {'name': 'stu1', 'school': '清华大学', 'tel': '1123', 'age': 18, 'score': 98, 'linkman': {'name': '张三', 'tel': '923'}},
        {'name': 'stu2', 'school': '攀枝花学院', 'tel': '8999', 'age': 28, 'score': 76, 'linkman': {'name': '李四', 'tel': '902'}},
        {'name': 'stu3', 'school': '成都理工大学', 'tel': '678', 'age': 20, 'score': 53, 'linkman': {'name': '小明', 'tel': '1123'}},
        {'name': 'stu4', 'school': '四川大学', 'tel': '9900', 'age': 30, 'score': 87, 'linkman': {'name': '小花', 'tel': '782'}},
        {'name': 'stu5', 'school': '西南交大', 'tel': '665', 'age': 22, 'score': 71, 'linkman': {'name': '老王', 'tel': '009'}},
        {'name': 'stu6', 'school': '成都理工大学', 'tel': '892', 'age': 32, 'score': 80, 'linkman': {'name': '老王2', 'tel': '0091'}},
        {'name': 'stu7', 'school': '四川大学', 'tel': '431', 'age': 17, 'score': 65, 'linkman': {'name': '老王3', 'tel': '0092'}},
        {'name': 'stu8', 'school': '攀枝花学院', 'tel': '2333', 'age': 16, 'score': 32, 'linkman': {'name': '老王4', 'tel': '0093'}},
        {'name': 'stu9', 'school': '攀枝花学院', 'tel': '565', 'age': 21, 'score': 71, 'linkman': {'name': '老王5', 'tel': '0094'}}
    ]
}

1获取班级位置

print(class1['address'])

2)获取班主任的名字和电话

d1 = class1['leader']
print(d1['name'],d1['tel'])

3)获取所有学生的姓名和分数

for stu in class1['students']:
    print(stu['name'], stu['score'])

4)获取所有学生联系人的名字和电话

for stu in class1['students']:
    stu1 = stu['linkman']
    print(stu1['name'], stu1['tel'])

5)获取班级最高分

stu_score = 0
for stu in class1['students']:
    if stu['score'] >= stu_score:
        stu_score = stu['score']
print(stu_score)

6)获取班级分数最高的学生的姓名

stu_score = 0
stu_name = ''
for stu in class1['students']:
    if stu['score'] >= stu_score:
        stu_score = stu['score']
        stu_name = stu['name']
print(stu_name)

7)计算班级学生的平均分

stu_score = 0
for stu in class1['students']:
    stu_score += stu['score']
print(stu_score / len(class1['students']))

8)统计班级中未成年人数

count = 0
for stu in class1['students']:
    if stu['age'] < 18:
        count += 1
print(count)

9)用字典统计每个学校的人数, 类似: {'清华大学': 1, '攀枝花学院': 3}

d1 = {}
stu_school = []
stu_school1 = []
count1 = 0
stu_sc = class1['students']
for stu in class1['students']:
    stu_school.append(stu['school'])
    if stu['school'] not in stu_school1:
        stu_school1.append(stu['school'])
for item in stu_school1:
    count1 = stu_school.count(item)
    d1[item] = count1
print(d1)

优化:

d1 = {}
for stu in class1['students']:
    stu_school_name = stu['school']
    if stu_school_name in d1:
        d1[stu_school_name] += 1
    else:
        d1[stu_school_name] = 1
print(d1)

联系我们

如果您对我们的服务有兴趣,请及时和我们联系!

服务热线:18288888888
座机:18288888888
传真:
邮箱:888888@qq.com
地址:郑州市文化路红专路93号