伯克利 CS61A 课堂笔记 07 —— Lists

本系列为加州伯克利大学著名 Python 基础课程 CS61A 的课堂笔记整理,全英文内容,文末附词汇解释。

目录

01 Lists 列表

02 Containers 容器

03 For Statements For 语句

04 Ranges 范围

05 List Comprehensions 列表理解

06 Box-and-Pointer Notation 箱点标记

Ⅰ The Closure Property of Data Types

Ⅱ Box-and-Pointer Notation in Environment Diagrams

07 Slicing 切片

08 Processing Container Values 处理容器值

Ⅰ sum(iterable[ , start]) -> value

Ⅱ max(iterable[ , key = func]) -> value and max(a, b, c, ... [ , key = func]) -> value

Ⅲ all(iterable) -> bool

附:词汇解释


01 Lists 列表

>>> digits = [0, 5, 2, 6]
>>> digits = [2-2, 1+1+3, 2, 2*3]

#The number of elements
>>> len(digits)

#An element selected by its index
>>> digits[3]
>>> getitem(digits, 3)

#Concarenation and repetition
>>> [2, 7] + digits * 2
>>> add([2, 7], mul(digits, 2))

#Nested lists
>>> pairs = [[10, 20], [30, 40]]
>>> pairs[1] #[30, 40]
>>> pairs[1][0] #30

02 Containers 容器

Built-in operators for testing whether an element appears in a compound value.

>>> digits = [0, 5, 2, 6]

>>> 0 in digits
True
>>> 1 not in digits
True
>>> not(1 in digits)
True

>>> '5' == 5
False
>>> '5' in digits
False
>>> [0, 5] in digits
False
>>> [0, 5] in [[0, 5], 2, 6]

03 For Statements For 语句

for <name> in <expression>:
    <suite>

① Evaluate the header <expression>, while must yield an iterable value (a sequence).

② For each element in that sequence, in order:

​        A Bind <name> to that element in the current frame.

​        B Execute the <suite>.

def count(s, value):
    '''Count the number of times that value occurs in sequence s.
    
    >>> count([1, 2, 1, 3, 1], 1)
    3
    '''
    
    total = 0
    #Name bound in the first frame of the current environment.
    for element in s: 
        if element == value:
            total += 1
     return total   

Sequence unpacking in for statements.

pairs = [[1, 2], [2, 3], [2, 2], [1, 1]]

count = 0
for x,y in pairs:
    if x == y:
        count += 1

04 Ranges 范围

A range is a sequence of consecutive integers.

Length: ending value - starting value

Element selection: starting value + index

>>> list(range(-2, 2))
[-2, -1, 0, 1]

#Range with a 0 starting value
>>> list(range(4))
[0, 1, 2, 3]
def sumBelow(n):
    total = 0
    for i in range(n):
        total += i
    return total    

def cheer():
    for _ in range(3):
        print('Go Bears!')

05 List Comprehensions 列表理解

>>> letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j']
>>> [letters[i] for i in [3, 4, 6, 8]]
['d', 'e', 'g', 'i']

>>> odds = [1, 3, 5, 7, 9]
>>> [x+1 for x in odds]
[2, 4, 6, 8, 10]
>>> [x for x in odds if 25 % x == 0]
[1, 5]
def divisors(n):
    return [1] + [x for x in range(2, n) if n % x == 0]

>>>divisors(1)
[1]
>>>divisors(4)
[1, 2]
>>>divisors(9)
[1, 3]
>>>divisors(12)
[1, 2, 3, 4, 6]

06 Box-and-Pointer Notation 箱点标记

Ⅰ The Closure Property of Data Types

A method for combing data values satisfies the closure property if the result of combination can itself be combined using the same method.

Closure is powerful because it permits us to create hierarchical structures.

Hierarchical structures are made up of parts, while themselves are made up of parts, and so on.

Attention: Lists can contain lists as elements (in addition to anything else).

Ⅱ Box-and-Pointer Notation in Environment Diagrams

Lists are represented as a row of index-labeled adjacent boxes, one per element.

Each box either contains a primitive value or points to a compound value.

07 Slicing 切片

>>> odds = [3, 5, 7, 9, 11]
>>> odds[1:3]
[5, 7]
>>> odds[:3]
[3, 5, 7]
>>> odds[1:]
[5, 7, 9, 11]
>>> odds[:]
[3, 5, 7, 9, 11]

Slicing creates new values.

08 Processing Container Values 处理容器值

Several built-in functions take iterable arguments and aggregate them into a value.

Ⅰ sum(iterable[ , start]) -> value

Return the sum of an iterable of numbers (NOT strings) plus the value of parameter 'start' (which defaults to 0). When the iterable is empty, return start.

>>> sum([2, 3, 4])
9
>>> sum([2, 3, 4], 5)
14

>>> [2, 3] + [4]
[2, 3, 4]
>>> sum([[2, 3], [4]], [])
[2, 3, 4]
Ⅱ max(iterable[ , key = func]) -> value and max(a, b, c, ... [ , key = func]) -> value

With a single iterable argument, return its largest item.

With two or more arguments, return the largest argument.

>>> max(range(5))
4
>>> max(0, 1, 2, 3, 4)
4
>>> max(range(10), key=lambda x: 7-(x-4)*(x-2))
3
>>> (lambda x: 7-(x-4)*(x-2))(3)
8
>>> (lambda x: 7-(x-4)*(x-2))(2)
7
>>> (lambda x: 7-(x-4)*(x-2))(4)
7
>>> (lambda x: 7-(x-4)*(x-2))(5)
4
Ⅲ all(iterable) -> bool

Return True if bool(x) is True for all values x in the iterable.

If the iterable is empty, return True.

>>> bool(5)
True
>>> bool(True)
True
>>> bool(-1)
True
>>> bool(0)
False
>>> bool('hello')
True
>>> bool('')
False
>>> range(5)
range(0, 5)
>>> [x<5 for x in range(5)]
[True, True, True, True, True]
>>> all([x<5 for x in range(5)])
True
>>> all(range(5))
False

附:词汇解释

yield / jiːld / 产生

iterable 可迭代的

consecutive / kənˈsekjətɪv / 连续的,不间断的

comprehension 理解,领悟

odd 奇数的

divisor/ dɪˈvaɪzər / 除数,因子 

closure property 闭包性质:在数学中,指一个集合在某种运算下的封闭性,即该运算的结果仍属于该集合

hierarchical / ˌhaɪəˈrɑːrkɪkl / structure 层次结构:是按层次划分的数据元素的集合,指定层次上元素可 以有零个或多个处于下一个层次上的直接所属下层元素

index-labeled 标记指数

adjacent / əˈdʒeɪs(ə)nt / 相邻的

primitive value 原始值

compound value 复合值

notation 标记

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

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

相关文章

数据结构--八大排序算法

1. 直接插入排序 当插入第 i(i>1) 个元素时&#xff0c;前面的 array[0],array[1],…,array[i-1] 已经排好序&#xff0c;此用 array[i] 的排序码与 array[i-1],array[i-2],… 的排序码顺序进行比较&#xff0c;找到插入位置即将 array[i] 插入&#xff0c;原来位置上的元素…

mapbox V3 新特性,添加下雪效果

&#x1f468;‍⚕️ 主页&#xff1a; gis分享者 &#x1f468;‍⚕️ 感谢各位大佬 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍⚕️ 收录于专栏&#xff1a;mapbox 从入门到精通 文章目录 一、&#x1f340;前言1.1 ☘️mapboxgl.Map 地图对象…

STM32 GPIO误触发问题全解析:从噪声干扰到电路设计优化

问题描述 在STM32项目中&#xff0c;配置某GPIO为内部上拉输入模式&#xff0c;并外接了一个上拉电阻。该引脚通过1米长的线束连接至电机控制模块&#xff0c;但出现以下异常&#xff1a; 弯折线束或手指触碰线束时&#xff0c;电机误触发&#xff08;MCU检测到低电平&#x…

pyqt自制简单浏览器(python)

确保已安装 PyQt5 和 PyQtWebEngine 库。 import sys from PyQt5.QtCore import QUrl from PyQt5.QtWidgets import QApplication, QMainWindow, QToolBar, QLineEdit, QAction, QListWidget, QVBoxLayout, QDialog, QMessageBox, QInputDialog, QTabWidget from PyQt5.QtWebE…

【人工智能】如何选择合适的大语言模型,是能否提高工作效率的关键!!!

DeepSeek R1入门指南 导读一、提示语差异1.1 指令侧重点不同1.2 语言风格差异1.3 知识运用引导不同 二、挑选原则2.1 模型选择2.2 提示语设计2.3 避免误区 结语 导读 大家好&#xff0c;很高兴又和大家见面啦&#xff01;&#xff01;&#xff01; 在前面的内容中&#xff0c…

​矩阵元素的“鞍点”​

题意&#xff1a; 一个矩阵元素的“鞍点”是指该位置上的元素值在该行上最大、在该列上最小。 本题要求编写程序&#xff0c;求一个给定的n阶方阵的鞍点。 输入格式&#xff1a; 输入第一行给出一个正整数n&#xff08;1≤n≤6&#xff09;。随后n行&#xff0c;每行给出n个整数…

ChatGPT搜索免费开放:AI搜索引擎挑战谷歌霸主地位全面分析

引言 2025年2月6日&#xff0c;OpenAI宣布ChatGPT搜索功能向所有用户免费开放&#xff0c;且无需注册登录。这一重大举措在搜索引擎行业引发巨大反响&#xff0c;有观点认为"谷歌搜索时代即将结束"。本文将深入分析ChatGPT生成式AI搜索对谷歌搜索业务及全球搜索市场…

NO.18十六届蓝桥杯备战|循环嵌套|乘法表|斐波那契|质数|水仙花数|(C++)

循环嵌套 循环嵌套的使⽤ while &#xff0c; do while &#xff0c; for &#xff0c;这三种循环往往会嵌套在⼀起才能更好的解决问题&#xff0c;就是我们所说的&#xff1a;循环嵌套。这三种循环都可以任意嵌套使⽤ ⽐如&#xff1a; 写⼀个代码&#xff0c;打印⼀个乘法⼝…

国际互联网安全日|Web3 世界的安全挑战与防护指南

2025 年 2 月 11 日是全球 “国际互联网安全日”&#xff08;Safer Internet Day&#xff09;。当我们跨越 Web2 迈入 Web3 时代&#xff0c;互联网安全的内涵也在悄然改变。在 Web2 时代&#xff0c;我们主要关注社交媒体隐私泄露、账号密码被盗、网络诈骗等传统安全问题。而在…

DeepseeK自动写作,自动将回答导出文档

在使用 DeepseeK 进行内容生成时&#xff0c;您是否也遇到了答案导出的困扰&#xff1f;无论是内容创作、数据分析还是项目报告&#xff0c;快速、高效地将生成的答案导出是提升工作效率的关键。本文将为您提供简单易行的解决方案&#xff0c;助您轻松实现 DeepseeK 答案的导出…

deep seek

1.介绍:DeepSeek是一款由国内人工智能公司研发的大型语言模型&#xff0c;拥有强大的自然语言处理能力&#xff0c;能够理解并回答问题&#xff0c;还能辅助写代码、整理资料和解决复杂的数学问题。免费开源&#xff0c;媲美ChatGPT 最近最火爆的AI对话程序。 www.deepseek.com…

数据结构中的邻接矩阵

一、概念 邻接矩阵&#xff08;Adjacency Matrix&#xff09;是图&#xff08;Graph&#xff09;的一种表示方法&#xff0c;用于描述图中顶点之间的连接关系。它是一种常见的数据结构&#xff0c;特别适用于表示稠密图&#xff08;即边数接近于顶点数平方的图&#xff09;。 …

微软AutoGen高级功能——Selector Group Chat

介绍 大家好&#xff0c;这次给大家分享的内容是微软AutoGen框架的高级功能Selector Group Chat(选择器群聊)&#xff0c;"选择器群聊"我在给大家分享的这篇博文的代码中有所体现微软AutoGen介绍——Custom Agents创建自己的Agents-CSDN博客&#xff0c;但是并没有详…

web前端开发中vscode常用的快捷键

1.快速复制一行 快捷键&#xff1a; shiftalt 下箭头(上箭头) 或者 ctrlc 然后 ctrlv 2.选定多个相同的单词 快捷键&#xff1a; ctrl d 先双击选定一个单词&#xff0c;然后按下 ctrl d 可以往下依次选择相同的单词。 这样同时修改相同的单词 3.全局替换某单词 当我们一个…

网络安全要学python 、爬虫吗

网络安全其实并不复杂&#xff0c;只是比普通开发岗位要学习的内容多一点。无论是有过编程基础还是零基础的都可以学习的。网络安全目前可就业的岗位从技术上可分为两部分&#xff1a;web安全和二进制逆向安全。web安全是网络安全的入门方向&#xff0c;内容简单&#xff0c;就…

深入解析哈希表:原理、实现与应用

目录 一、哈希表是什么&#xff1f; 1.1 基本概念 1.2 哈希表的工作原理 二、哈希表的使用方法 2.1 C 标准库中的哈希表 示例&#xff1a;std::unordered_map 的基本用法 2.2 自定义哈希函数 示例&#xff1a;自定义哈希函数 三、什么时候使用哈希表&#xff1f; 3.1…

CentOS-Stream 9更换RT实时内核

文章目录 1 安装环境1.1 Centos9原生内核示意 2 下载实时内核3 CentOS更换阿里YUM源3.1 更换源3.2 添加文件内容3.2.1 centos.repo3.2.2 centos-addons.repo 3.3 yum源生效 4 安装epel-release5 安装必要库和软件6 配置内核6.1 更改内核文件权限6.2 使用tar命令解压内核源码文件…

微软AutoGen高级功能——Magentic-One

介绍 大家好&#xff0c;博主又来给大家分享知识了&#xff0c;这次给大家分享的内容是微软AutoGen框架的高级功能Magentic-One。那么它是用来做什么的或它又是什么功能呢&#xff0c;我们直接进入正题。 Magentic-One Magnetic-One是一个通用型多智能体系统&#xff0c;用于…

国产编辑器EverEdit - 极简追梦人的福音:迷你查找

1 迷你查找 1.1 应用场景 某些场景下&#xff0c;用户不希望调出复杂的查找对话框&#xff0c;此时可以使用迷你查找窗口。 1.2 使用方法 选择主菜单查找 -> 迷你查找&#xff0c;或使用快捷键Ctrl Alt F&#xff0c;会在右上角弹出迷你查找窗口&#xff0c;如下图所示…

【第4章:循环神经网络(RNN)与长短时记忆网络(LSTM)— 4.5 序列标注与命名实体识别】

一、引言 嘿,各位技术小伙伴们!今天咱们要来深入聊聊循环神经网络(RNN)和长短时记忆网络(LSTM),这俩在序列标注和命名实体识别领域那可是相当厉害的角色。咱就从最基础的概念开始,一步步揭开它们神秘的面纱,看看它们到底是怎么在实际应用中发挥巨大作用的。 二、序列…