大爽Python入门教程 3-4 实践例题
大爽Python入门公开课教案
点击查看教程总目录
1. 求和
使用循环,计算列表所有项的和,并输出这个和。
列表示例
lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11]
实现代码如下
lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11]
s = 0
for item in lst:
s += item
print(s)
输出为
98
上面是用for循环实现的,
下面用while来实现下,
lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11]
s = 0
i = 0
while i < len(lst):
item = lst[i]
s += item
i += 1
print(s)
输出也是98
拓展说明:很多for循环实现的功能,都可以使用while循环来实现
for循环的特点是遍历可迭代对象。
while循环中,可以添加一个随循环次数增长的index,来实现同样的遍历。
while循环的特点是按条件循环。
用for循环去实现按条件来循环,比较难。
2. 寻找最大值
使用循环和判断,寻找出列表的最大值,并输出该最大值及其索引。
列表示例
lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11]
思路分析 :
寻找列表中的最大值及其索引,
一般会选择先将列表开头的项(即第一项)作为最大值初始值。
然后(使用循环)依次用后面的项与该最大值作比较,
如果后面的项比该最大值更大,则更新这个最大值(也更新最大值索引)。
当循环执行完后,列表中的所有项都经过了一轮比较。
此时得到的最大值,必然是列表所有项的最大值。
实现代码如下
lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11]
max_index = 0
max_value = lst[max_index]
for i in range(1, len(lst)):
if lst[i] > max_value:
max_index = i
max_value = lst[i]
print("Max Value: %s" % max_value)
print("Max Value's index: %s" % max_index)
输出如下
Max Value: 21
Max Value's index: 5
补充分析:
第一题遍历时,直接遍历的列表中的所有的项。
第二题遍历时,遍历的是列表中第二项开始所有项的索引。
什么时候遍历项,什么时候遍历索引,取决与实际情景的需要。
比如第二题是因为要求最后输出时也输出最大项的索引。
3 求加权和
加权和:
比如现有列表[a1, a2, a3], 其权重列表为[w1, w2, w3]。
那么其加权和为a1*w1 + a2*w2 + a3*w3。
现有数据列表lst和其对应权重列表weights如下
lst = [8, 5, 7, -12, 19, 21, 10, -3, 2, 11]
weights = [1, 2, 5, 3, 4, 6, 8, 7, 2, 4]
求lst中数据的加权和。
补充要求:忽略lst中小于0的数据(即不对这些数据算加权,也不计入和)。
代码实现
lst = [8, 5, 7, -12, 19, 21, 10, -3, 2, 11]
weights = [1, 2, 5, 3, 4, 6, 8, 7, 2, 4]
s = 0
for i in range(len(lst)):
item = lst[i]
if item >= 0:
weight = lst[i]
v = item * weight
s += v
print(s)
输出为1165。
上面的if判断是判断的数据大于等于0时才执行。
下面我们用continue实现,数据小于0时跳过。
代码如下
lst = [8, 5, 7, -12, 19, 21, 10, -3, 2, 11]
weights = [1, 2, 5, 3, 4, 6, 8, 7, 2, 4]
s = 0
for i in range(len(lst)):
item = lst[i]
if item < 0:
continue
weight = lst[i]
v = item * weight
s += v
print(s)
大爽Python入门教程 3-4 实践例题的更多相关文章
- 大爽Python入门教程 2-5 *拓展实践,对比与思考
大爽Python入门公开课教案 点击查看教程总目录 本文偏难. 推荐等第一二三四章上完后,回过来拓展阅读. 基础情景思考 假设有这样一张成绩表 最左边的一列是名字,起名麻烦. 这里直接用ABC...来 ...
- 大爽Python入门教程 2-3 字符串,列表,字典
大爽Python入门公开课教案 点击查看教程总目录 除了通用的序列方法, 列表和字符串还有些自己的专属方法. 后面介绍有些是英中文对照介绍(英文来自官方文档), 便于大家更深入的去理解其意思. 灵活的 ...
- 大爽Python入门教程 1-4 习题
大爽Python入门公开课教案 点击查看教程总目录 1 [思考]方向变换 小明同学站在平原上,面朝北方,向左转51次之后(每次只转90度), 小明面朝哪里?小明转过了多少圈? (360度为一圈,圈数向 ...
- 大爽Python入门教程 3-3 循环:`for`、`while`
大爽Python入门公开课教案 点击查看教程总目录 for循环 可迭代对象iterable 不同于其他语言. python的for循环只能用于遍历 可迭代对象iterable 的项. 即只支持以下语法 ...
- 大爽Python入门教程 3-5 习题
大爽Python入门公开课教案 点击查看教程总目录 1 求平方和 使用循环,计算列表所有项的平方和,并输出这个和. 列表示例 lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, ...
- 大爽Python入门教程 3-6 答案
大爽Python入门公开课教案 点击查看教程总目录 1 求平方和 使用循环,计算列表所有项的平方和,并输出这个和. 列表示例 lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, ...
- 大爽Python入门教程 3-1 布尔值: True, False
大爽Python入门公开课教案 点击查看教程总目录 1 布尔值介绍 从判断说起 回顾第一章介绍的简单的判断 >>> x = 10 >>> if x > 5: ...
- 大爽Python入门教程 3-2 条件判断: if...elif..else
大爽Python入门公开课教案 点击查看教程总目录 简单回顾if 回顾下第一章的代码 >>> x = 5 >>> if x > 0: ... print(&q ...
- 大爽Python入门教程 总目录
作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 大爽Python入门公开课教案 本篇博客为公开课教案目录,正文内容在目录章节链接的博客里 除目录本身外,没有链接的章节, ...
随机推荐
- 最详细的搭建web自动化测试网站,别再说你没有实战项目(文未有福利)
一步步教你搭建开源网站 环境准备: Tomcat shopping商城文件 jdk环境 Mysql环境 解压shopping.rar拷贝至tomcat/webapps 在navicat导入数据库db_ ...
- 【Golang】Go 通过结构(struct) 实现接口(interface)
一.通过结构(struct) 实现 接口(interface) 1.在了解iris框架的时候,经常看到有这样去写的使用一个空结构体作为接收器,来调用方法,有点好奇这样做有什么意义. 解释:在 Go 语 ...
- 从commons-beanutils反序列化到shiro无依赖的漏洞利用
目录 0 前言 1 环境 2 commons-beanutils反序列化链 2.1 TemplatesImple调用链 2.2 PriorityQueue调用链 2.3 BeanComparator ...
- ElasticJob 3.0.0:打造面向互联网生态和海量任务的分布式调度解决方案
ElasticJob 于 2020 年 5 月 28 日重启并成为 Apache ShardingSphere 子项目.新版本借鉴了 ShardingSphere 可拔插架构的设计理念,对内核进行了大 ...
- Java基础之(六):变量、运算符与JavaDoc
变量.常量 一.变量的命名规范 首字母只能以字母(A-Z或者a-z)或者美元符($)或者下划线(_)开头,不能以数字开头,首字母之后只能跟字母(AZ或者az)或者数字,不能跟美元符或者下划线 源码 p ...
- 前段---css
css主要是用来做如何显示html元素的 当浏览器读到一个样式表,它就会按照这个样式表来对文档做渲染 注意:每一个css样式表都是由两个部分组成的, 1,选择器 2,声明 声明又包括属性值和属性,每个 ...
- scrapy爬虫简单项目入门练习
[写在开头] scrapy环境配置配置好了之后,开始着手简单项目入门练习.关于环境配置见上一篇博客https://www.cnblogs.com/ljxh/p/11235079.html. [正文部分 ...
- ByteCTF2021 double sqli
double sqli easy sqli http://39.105.175.150:30001/?id=1 http://39.105.116.246:30001/?id=1 http://39. ...
- 【数据结构与算法Python版学习笔记】递归(Recursion)——定义及应用:分形树、谢尔宾斯基三角、汉诺塔、迷宫
定义 递归是一种解决问题的方法,它把一个问题分解为越来越小的子问题,直到问题的规模小到可以被很简单直接解决. 通常为了达到分解问题的效果,递归过程中要引入一个调用自身的函数. 举例 数列求和 def ...
- Beta实际开发与初始计划的比较
零.说明 本篇博客为Beta阶段开始十天后,实际开发工作与初始计划的比较 截止至本篇博客发布为止,团队所有成员已完成计网考试,将在本周日进行充分的接口测试 一.比较 1.与初始计划对比 初始计划 实际 ...