【Python】常用数据结构

1、熟悉字典和列表

2、使用条件判断语句

3、list列表中计算


1、从键盘输人一个正整数列表,以-1结束,分别计算列表中奇数和偶数的和。

(1)源代码:

# 初始化奇数和偶数的和为0
odd_sum = 0
even_sum = 0
#输入
while True:
    num = int(input("请输入一个正整数(输入-1结束): "))
    if num == -1:
        break  # 如果输入-1,则跳出循环
    if num < 0:
        print("错误:请输入正整数!")
        continue  # 如果输入负数,则忽略这次输入并继续下一次循环

    # 根据输入的数是奇数还是偶数,分别累加到对应的和中
    if num % 2 == 0:
        even_sum += num
    else:
        odd_sum += num

    # 输出奇数和偶数的和
print("奇数的和为:", odd_sum)
print("偶数的和为:", even_sum)

(2)运行结果截图 :

2、已知10个学生的成绩为68、75、32、99、78、45、88、72、83、78,请将成绩存放在列表中,请对其进行统计,输出优(100~90)、良(89~80)、中(79~60)差(59~0)4个等级的人数。

(1)源代码:

# 学生成绩列表
scores = [68, 75, 32, 99, 78, 45, 88, 72, 83, 78]

# 等级分类的边界值
excellent_lower = 90
good_lower = 80
medium_lower = 60

# 初始化等级人数计数器
excellent_count = 0
good_count = 0
medium_count = 0
poor_count = 0

# 遍历成绩列表,进行等级分类和统计
for score in scores:
    if score >= excellent_lower:
        excellent_count += 1
    elif score >= good_lower:
        good_count += 1
    elif score >= medium_lower:
        medium_count += 1
    else:
        poor_count += 1

    # 输出结果
print("优(100~90)的人数:", excellent_count)
print("良(89~80)的人数:", good_count)
print("中(79~60)的人数:", medium_count)
print("差(59~0)的人数:", poor_count)

(2)运行结果截图 :

3、利用while循环创建一个包含10个奇数的列表,如果输入的不是奇数要给出提示信息并能继续输人,然后计算该列表的和与平均值。

(1)源代码

odd_numbers = []

# 使用while循环来确保列表中有10个奇数
while len(odd_numbers) < 10:
    # 获取用户输入
    num = int(input("请输入一个奇数(如果输入的不是奇数,会重新提示): "))

    # 检查输入是否为奇数
    while num % 2 == 0:
        print("错误:输入的不是奇数,请重新输入。")
        num = int(input("请输入一个奇数: "))

        # 将奇数添加到列表中
    odd_numbers.append(num)

# 计算列表的和
sum_of_odd_numbers = sum(odd_numbers)

# 计算列表的平均值
average_of_odd_numbers = sum_of_odd_numbers / len(odd_numbers)

# 输出结果
print("包含10个奇数的列表:", odd_numbers)
print("列表的和:", sum_of_odd_numbers)
print("列表的平均值:", average_of_odd_numbers)

(2)运行结果截图

4、请用字典编程,已知某班学生的姓名和成绩输出这个班的学生姓名和成绩,并求出全班同学的人数和平均分并显示。

(1)源代码

# 初始化一个空字典来存储学生的姓名和成绩  
students = {}  
  
# 输入学生姓名和成绩,并存储到字典中  
names_scores = [  
    ("张三", 85),  
    ("李四", 78),  
    ("徐来", 45),  
    ("沙思思", 96),  
    ("如一", 65),  
    ("司音", 90),  
    ("赵敏", 78),  
    ("张旭宁", 99),  
    ("柏龙", 60),  
    ("思琪", 87)  
]  
  
for name, score in names_scores:  
    students[name] = score  
  
# 输出学生姓名和成绩  
print("学生姓名和成绩:")  
for name, score in students.items():  
    print(f"{name}: {score}")  
  
# 计算全班人数  
total_students = len(students)  
print(f"全班人数:{total_students}")  
  
# 计算全班平均分  
total_score = sum(students.values())  
average_score = total_score / total_students  
print(f"全班平均分:{average_score:.2f}") 

(2)运行结果截图

5、某家商店根据客户消费总额的不同将客户分为不同的类型。如果消费总额>10万元,为铂金卡客户(platinum);如果消费总额>5万元且<10万元,为金卡客户(gold);如果消费总额>3万元且<5万元,为银卡客户(silver);如果消费总额<3万元,为普卡客户(ordinary)。现有一批顾客的消费金额(单位:万元)分别为2.3、4.5、24、17、1、7.8、39、210.5、1.2、4、1、0.3,将消费金额存储在列表list1中,输出一个字典,分别以platinum、gold、silver、ordinary为键,以各客户类型人数为值。

(1)源代码

# 定义消费金额列表  
list1 = [2.3, 4.5, 24, 17, 1, 7.8, 39, 210.5, 1.2, 4, 1, 0.3]  
  
# 初始化客户类型字典  
customer_types = {  
    'platinum': 0,  # 铂金卡客户人数  
    'gold': 0,      # 金卡客户人数  
    'silver': 0,    # 银卡客户人数  
    'ordinary': 0   # 普卡客户人数  
}  
  
# 遍历消费金额列表,进行分类和计数  
for amount in list1:  
    if amount > 10:  
        customer_types['platinum'] += 1  
    elif 5 < amount <= 10:  
        customer_types['gold'] += 1  
    elif 3 < amount <= 5:  
        customer_types['silver'] += 1  
    else:  # amount <= 3  
        customer_types['ordinary'] += 1  
  
# 输出客户类型字典  
print(customer_types)

(2)运行结果截图

6、某企业为职工发放奖金:如果人职超过5年,且销售业绩超过15000元的员工,奖金比例为0.2;销售业绩超过10000元的员工,奖金比例为0.15:销售业绩超过5000元的员工,奖金比例为0.1;其他奖金比例为0.05。如果是人职不超过5年,且销售业绩超过4000的员工,奖金比例为0.045;否则为0,01。输人人职年限、销售业绩,输出奖金比例、奖金,并将奖金存放到列表中并输出该列表。人职年限(为整数)输入一1的时候结束输人,为了简化所有输入均假定正确,不需判断小于0的情况。奖金为销售业绩与奖金比例的乘积。

(1)源代码:

list = []
while True:
    years = int(input("请输入入职年限为:"))
    if years >= 5:
        num = float(input("请输入销售业绩为:"))
        if num > 15000:
            proportion = 0.2
        elif num > 10000:
            proportion = 0.15
        elif num > 5000:
            proportion = 0.1
        else:
            proportion = 0.05
        award = proportion * num
        list.append(award)
        print("奖金比例为:", proportion, "奖金为:", award)
    elif years >= 0 and years < 5:
        num = float(input("请输入销售业绩为:"))
        if num > 4000:
            proportion = 0.045
        else:
            proportion = 0.01
        award = proportion * num
        list.append(award)
        print("奖金比例为:", proportion, "奖金为:", award)
    else:
        print("结束输入。")
        break
print()
print("奖金列表为:", list)

(2)运行结果截图 :

7、输入5个整数放到列表list1中,输出下标及值,然后将列表listl中大于平均值的元素组成一个新列表list2,输出平均值和列表list2。请利用列表推导式解决该问题。

(1)源代码:

print("请输入五个整数")

list1 = []

for i in range(5):

    n = int(input("请输入第"+str(i+1)+"个:"))

    list1.append(n)

avg = sum(list1)/len(list1)

list2 = [i for i in list1 if i > avg]

print()

print("平均值为:",avg)

print("list2为:",list2)

(2)运行结果截图 :

8、编写程序,将由1、2、3、4这4个数字组成的每位数都不相同的所有三位数存入一个列表中并输出该列表。请利用列表推导式解决该问题。

(1)源代码

a = [1,2,3,4]
b = [i*100 + j*10 + k for i in a for j in a for k in a if i!= j and i!= k and j!= k ]
print(b)

(2)运行结果截图

9、编写程序,给定列表[1,9,8,7,6,5,13,3,2,1],先输出原列表,删除其中所有奇数后再输出。请利用列表推导式解决该问题。

(1)源代码

a = [1,9,8,7,6,5,13,3,2,1]
b = [i for i in a if i%2 == 0]
print(a)
print(b)

(2)运行结果截图

10、百钱买百鸡:一只公鸡5元钱,一只母鸡3元钱,三只小鸡1元钱,现在要用100 元钱买 100 只鸡,问公鸡、母鸡、小鸡各多少只?请利用列表推导式解决该问题。

(1)源代码

list = [(a,b,c) for a in range(0,21) for b in range(0,34) for c in range(0,301) if 5*a + 3*b + c/3 ==100 and a + b + c ==100]
print(list)

(2)运行结果截图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/587840.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java+jsp+Oracle+Tomcat 记账管理系统论文(二)

⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️ ➡️点击免费下载全套资料:源码、数据库、部署教程、论文、答辩ppt一条龙服务 ➡️有部署问题可私信联系 ⬆️⬆️⬆️​​​​​​​⬆️…

分布式链路追踪工具Sky walking详解

1&#xff0c;为什么要使用分布式链路追踪工具 随着分布式系统和微服务架构的出现&#xff0c;且伴随着用户量的增加&#xff0c;项目的体量变得十分庞大&#xff0c;一次用户请求会经过多个系统&#xff0c;不同服务之间调用关系十分复杂&#xff0c;一旦一个系统出现错误都可…

微软如何打造数字零售力航母系列科普06 - 如何使用微软的Copilot人工智能

如何使用微软的Copilot人工智能&#xff1f; Copilot和ChatGPT有很多相似之处&#xff0c;但微软的聊天机器人本身就有一定的优势。以下是如何对其进行旋转&#xff0c;并查看其最引人注目的功能。 ​​​​​​​ &#xff08;资料来源&#xff1a;Lance Whitney/微软&…

C++ | 类和对象(中) (构造函数 | 析构函数 | 拷贝构造函数 | 赋值运算符重载 | 取地址 | const取地址)

目录 默认成员函数 构造函数 构造函数是什么 构造函数特征 什么是默认构造函数 注意事项 编译器自动生成的默认构造 缺省值 对象如何传值给构造函数 初始化列表 析构函数 析构函数的特征 编译器默认生成的析构函数 总结 拷贝构造函数 拷贝构造函数的使用场景 拷…

使用ipxe安装现有的装机环境

iPXE和传统PXE区别 iPXE和传统PXE&#xff08;Pre-boot Execution Environment&#xff0c;预启动执行环境&#xff09;的主要区别在于它们的功能和协议支持。以下是两者的主要区别&#xff1a; 协议支持&#xff1a; PXE仅支持TFTP&#xff08;trivial file transfer protoco…

【linuxC语言】空洞文件

文章目录 前言一、空洞文件1.1 空洞文件的介绍1.2 用途 二、示例代码总结 前言 在 Linux 系统编程中&#xff0c;空洞文件是一种特殊类型的文件&#xff0c;它包含了逻辑上的空洞&#xff0c;也就是说文件中的某些部分并没有实际写入数据。尽管文件在逻辑上可能非常大&#xf…

向eclipse中的项目导入jdk、tomcat

前言&#xff1a; 有些项目无法正常启动可能是因为他的基础配置不正确或者没配置&#xff0c;eclipse中的javaweb项目常见的配置就是jdk、tomcat&#xff0c;这三者配置的方式大概相同&#xff0c;以下是相关操作。我的环境是eclipse2018。 一、jdk 在项目上右键选中propert…

java-Spring-mvc-(请求和响应)

目录 &#x1f4cc;HTTP协议 超文本传输协议 请求 Request 响应 Response &#x1f3a8;请求方法 GET请求 POST请求 &#x1f4cc;HTTP协议 超文本传输协议 HTTP协议是浏览器与服务器通讯的应用层协议&#xff0c;规定了浏览器与服务器之间的交互规则以及交互数据的格式…

Swiper轮播图

版本&#xff1a;“swiper”: “^6.8.4”, 处理每分钟重新请求数据后&#xff0c;播放卡顿&#xff0c;快速闪&#xff0c;没按照设置时间播放等bug 以下是直接vue2 完整的组件代码 使用&#xff1a; <SwiperV :imgList“swiperList” / <template><div class"…

键盘更新计划

作为 IT 搬砖人&#xff0c;一直都认为键盘没有什么太大关系。 每次都是公司发什么用什么。 但随着用几年后&#xff0c;发现现在的键盘经常出问题&#xff0c;比如说调节音量的时候通常莫名其妙的卡死&#xff0c;要不就是最大音量要不就是最小音量。 按键 M 不知道什么原因…

hadoop学习---基于hive的聊天数据分析报表可视化案例

背景介绍&#xff1a; 聊天平台每天都会有大量的用户在线&#xff0c;会出现大量的聊天数据&#xff0c;通过对聊天数据的统计分析&#xff0c;可以更好的对用户构建精准的用户画像&#xff0c;为用户提供更好的服务以及实现高ROI的平台运营推广&#xff0c;给公司的发展决策提…

50. 【Android教程】xml 数据解析

xml 是一种标记扩展语言&#xff08;Extension Mark-up Language&#xff09;&#xff0c;学到这里大家对 xml 语言一定不陌生&#xff0c;但是它在 Android 中的运用其实只是冰山一角。抛开 Android&#xff0c;XML 也被广泛运用于各种数据结构中。在运用 xml 编写 Android 布…

自动化机器学习——网格搜索法:寻找最佳超参数组合

自动化机器学习——网格搜索法&#xff1a;寻找最佳超参数组合 在机器学习中&#xff0c;选择合适的超参数是模型调优的关键步骤之一。然而&#xff0c;由于超参数的组合空间通常非常庞大&#xff0c;手动调整超参数往往是一项耗时且困难的任务。为了解决这个问题&#xff0c;…

Meditron:基于 Llama 完全开源的医学大语言模型

健康危机就在眼前&#xff0c;当医疗资源有限时&#xff0c;每一秒钟都至关重要&#xff01;Meditron 就像一位忠实的医疗助手&#xff0c;提供基于证据的护理建议和情境意识的推荐&#xff0c;帮助医疗工作者在诊断和治疗过程中做出更准确的决策。 在资源有限的医疗环境中&am…

CTFHub-Web-文件上传

CTFHub-Web-文件上传-WP 一、无验证 1.编写一段PHP木马脚本 2.将编写好的木马进行上传 3.显示上传成功了 4.使用文件上传工具进行尝试 5.连接成功进入文件管理 6.上翻目录找到flag文件 7.打开文件查看flag 二、前端验证 1.制作payload进行上传发现不允许这种类型的文件上传 …

React | React.cloneElement 的使用

我看到同事的代码里有 cloneElement&#xff0c;于是去了解了一下这个函数。 就跟它的名字一样&#xff0c;克隆元素&#xff0c;可以基于一个元素创建一个新的元素&#xff0c;并且为新元素添加新的属性或者覆盖已有的属性。 下面是一个简单例子&#xff1a; .node1 {backg…

使用qemu调试NVME driver

参考nvme驱动相关的博客&#xff0c;可以使用qemu buildroot进行nvme驱动的流程debug。 一、QEMU编译 首先需要编译qemu&#xff0c;可以参考QEMU编译。wget下载最新版本的QEMU&#xff0c;编译之前&#xff0c;最好检查下依赖包是否安装&#xff0c;避免安装过程出现各种错…

算法二:DOM - 将DOM节点元素转换成JSON字符串

题目&#xff1a; 将DOM节点元素转换成JSON的格式 例如 <div class"root"><div class"child1"><p></p></div><span></span><div><div><p></p></div></div><p></…

Springboot+Vue+小程序+基于微信小程序护农远程看护系统

开发平台为idea&#xff0c;maven管理工具&#xff0c;Mybatis操作数据库&#xff0c;根据市场数字化需要为农户打造小程序可远程查看农场的种植情况。项目是调试&#xff0c;讲解服务均可有偿获取&#xff0c;需要可在最下方QQ二维码处联系我。 SpringbootVue小程序&#xff…

Pyspark+关联规则 Kaggle购物篮分析案例

数据集地址&#xff1a;Market Basket Analysis | Kaggle 我的NoteBook地址&#xff1a;pyspark Market Basket Analysis | Kaggle 零售商期望能够利用过去的零售数据在自己的行业中进行探索&#xff0c;并为客户提供有关商品集的建议&#xff0c;这样就能提高客户参与度、改…