【Python】常用数据结构

news2024/12/23 23:06:22

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.coloradmin.cn/o/1631401.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【InternLM】基于弱智吧数据的微调数据构造实验

1. 数据处理流程 在AI领域有句名言&#xff1a;数据和特征决定了机器学习的上限&#xff0c;而模型和算法只是逼近这个上限而已。可见数据对整个AI的决定性影响&#xff0c;在模型开源化的今天&#xff0c;很多厂商的模型结构都大同小异&#xff0c;那影响最终模型的一大决定因…

Cranck-Nicolson隐式方法解线性双曲型方程

Cranck-Nicolson隐式方法解线性双曲型方程 Cranck-Nicolson方法在抛物型方程里面比较常用&#xff0c;双曲型方程例子不多&#xff0c;该方法是二阶精度&#xff0c;无条件稳定&#xff0c;然而&#xff0c;数值震荡比较明显&#xff0c;特别是时间演化比较大以及courant数比较…

基于Spring Boot的实验室管理系统设计与实现

基于Spring Boot的实验室管理系统设计与实现 开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/idea 系统部分展示 管理员登录界面&#xff0c;管理员通过后台登录窗口进…

Maven介绍 主要包括Maven的基本介绍,作用,以及对应的Maven模型,可以对Maven有一个基本的了解

1、Maven介绍 1.1 什么是Maven Maven是Apache旗下的一个开源项目&#xff0c;是一款用于管理和构建java项目的工具。 官网&#xff1a;https://maven.apache.org/ Apache 软件基金会&#xff0c;成立于1999年7月&#xff0c;是目前世界上最大的最受欢迎的开源软件基金会&…

Visual Studio Code基础:打开一个编辑器(文件)时,覆盖了原编辑器

相关阅读 VS codehttps://blog.csdn.net/weixin_45791458/category_12658212.html?spm1001.2014.3001.5482 在使用vscode时&#xff0c;偶尔会出现这样的问题&#xff1a;打开了某个编辑器&#xff08;文件&#xff0c;下面统称文件&#xff09;后&#xff0c;再打开其他文件…

【触摸案例-控件不能响应的情况 Objective-C语言】

一、接下来,我们来说这个“控件不能响应的情况”, 1.素材里边,有一个“不接受用户交互的情况”,这么一个代码,把它打开, 把这个项目啊,复制过来,改一个名字,叫做“04-控件不能响应的情况”, 打开之后,command + R,运行一下, 在storyboard上,你也可以看得出来,我…

系统服务(22年国赛)—— nmcli命令部署VXLAN

前言&#xff1a;原文在我的博客网站中&#xff0c;持续更新数通、系统方面的知识&#xff0c;欢迎来访&#xff01; 系统服务&#xff08;22年国赛&#xff09;—— VXLAN服务部署https://myweb.myskillstree.cn/118.html 目录 题目&#xff1a; AppSrv 关闭防火墙和SEli…

哈夫曼编码---一种无损数据压缩算法

哈夫曼编码是一种无损数据压缩算法&#xff0c;该算法在数据压缩&#xff0c;存储和网络传输等领域广泛引用&#xff0c;对互联网的发展也产生了深远的影响。 大家熟知的数据无损压缩软件&#xff0c;如WinRAR&#xff0c;gzip&#xff0c;bzip&#xff0c;lzw&#xff0c;7-z…

ThreeJs 环境配置及遇到问题的解决方法

一、环境搭建 ThreeJs在实际在实际使用中更多的是结合框架开发例如&#xff1a;vue框架、react框架&#xff0c;在使用时需要配置开发环境&#xff0c;本文使用的是vscode ThreeJs NodeJs vue 1、ThreeJs安装 下载路径&#xff1a;GitHub - mrdoob/three.js: JavaScript…

如何进行制造设备数据汇集,发挥数据的价值?

数字化转型正深刻推动制造企业实现远程监控、提高生产效率、降低生产成本、优化产品质量及明晰精细化方向。并且工业互联网的发展离不开工业数据的应用&#xff0c;而制造设备数据汇集正是应用的基础。但制造设备数据汇集存在以下难点及痛点&#xff1a; 1、安全把控难 关键的…

windows日志怎么打开/查看?

windows日志里可以查看到系统进行的各种操作,包括正常开关机记录、dhcp配置警告信息等等,不过很多小伙伴并不知道怎么打开windows日志,为此为大家整理了三种快速打开windows系统日志的方法,大家有需要的话赶紧来看看吧。 目录 一、方法1 二、方法2 三、方法3 (推荐) 一…

基于SpringBoot+Vue乡村养老服务管理系统

项目介绍&#xff1a; 使用旧方法对乡村养老服务管理系统登录的信息进行系统化管理已经不再让人们信赖了&#xff0c;把现在的网络信息技术运用在乡村养老服务管理系统登录的管理上面可以解决许多信息管理上面的难题&#xff0c;比如处理数据时间很长&#xff0c;数据存在错误…

如何用Python语言实现远程控制4路控制器/断路器

如何用Python语言实现远程控制4路控制器/断路器呢&#xff1f; 本文描述了使用Python语言调用HTTP接口&#xff0c;实现控制4路控制器/断路器&#xff0c;支持4路输出&#xff0c;均可独立控制&#xff0c;可接入各种电器。 可选用产品&#xff1a;可根据实际场景需求&#xf…

网红大佬的面子,高阶智驾的里子 | 2024北京车展

相关阅读&#xff1a;2023北京车展 《没有争奇斗艳的车模&#xff0c;只有往死里卷的智能汽车》。 文&#xff5c;刘俊宏 李想、李斌绑定“车圈新顶流”雷军互相抬轿子&#xff0c;红衣大叔周鸿祎高情商点评各家汽车新品...... 为了流量&#xff0c;今年车企大佬们比任何时候…

2024李卜常识王小晨申论类比刷题课

2024年&#xff0c;李卜常识与王小晨申论类比刷题课成为备考公务员考试的热门选择。李卜老师以其深厚的学识&#xff0c;为学员们剖析常识的精髓&#xff1b;而王小晨老师则通过类比刷题的方式&#xff0c;帮助学员们掌握申论的技巧。这两门课程相互补充&#xff0c;让学员们在…

「51媒体」政企宣传邀请媒体的作用?

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 政企宣传邀请媒体的作用主要体现在以下几个方面&#xff1a; 提升品牌知名度&#xff1a;通过媒体广泛报道活动内容、亮点及企业形象&#xff0c;可以提升企业或政府的品牌知名度。 增加…

kaggle(4) Regression with an Abalone Dataset 鲍鱼数据集的回归

kaggle&#xff08;4&#xff09; Regression with an Abalone Dataset 鲍鱼数据集的回归 import pandas as pd import numpy as npimport xgboost import lightgbm import optuna import catboostfrom sklearn.model_selection import train_test_split from sklearn.metrics …

JS----前端不同格式的 UUID生成

前端 UUID生成 export const generateUUID () > {let timestamp new Date().getTime()let performanceNow (typeof performance ! undefined && performance.now && performance.now() * 1000) || 0return xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx.replac…

【Linux】进程的控制①之进程创建与进程退出

一 、进程的创建 1、fork函数 fork函数功能&#xff1a;从已经存在的进程中创建一个新进程。新进程为子进程&#xff0c;原进程为父进程。 fork函数创建进程过后&#xff0c;父子进程代码和数据是共享的。在前面也讲过。 2.函数的返回值 如果进程创建成功&#xff0c;给父进…

ResNeXt网络结构

一、简介 在ResNet的基础上&#xff0c;对残差结构的block进行了更新。 ResNeXt网络是一种深度神经网络架构&#xff0c;可以视为对ResNet&#xff08;残差网络&#xff09;的改进和升级。ResNeXt结合了VGG网络的堆叠相同基础模块的策略以及Inception系列网络中的split-trans…