6.6 练习

最后更新于:2022-04-02 00:29:51

## 6.6 练习 1\. 分别举例说明现实中的什么信息适合用列表、元组、集合、字典来表示和处理。 2\. 以统计指标的计算为例,说明为什么同样是处理大量数据,有的程序不需要使用数据集 合体来存储大量数据,而有的程序则需要。 3\. 给定两个列表 `s1 = [2005,7,2,8]`和 `s2 = [’L’,’u’,’c’,'y']`,计算以下表达式: (1)`s1 + s2` (2)`2 * s1` (3)`s1[1]` (4)`s2[1:3]` (5)`s1[1] + s2[-1]` 4\. 对第 3 题中的列表进行以下操作后,s1 和 s2 的值是什么。各小题之间是独立的。 (1)`s1.remove(2)` (2)`s1.sort().reverse()` (3)`s1.append([s2.index(’c’)])` (4)`s2.pop(s1.pop(2))` (5)`s2.insert(s1[2],’I’)` 5\. 修改程序 6.1,使程序能计算更多统计指标(如标准差)。 6\. 程序设计:自己编程实现 Python 列表对象的方法。 (1)编写函数 `count(aList, x)`,功能同 `aList.count(x)`; (2)编写函数 `isin(aList, x)`,功能同 `x in aList`; (3)编写函数 `index(aList, x)`,功能同 `aList.index(x)`; (4)编写函数 `reverse(aList)`,功能同 `aList.reverse()`。 7\. 编写函数 `shuffle(aList)`,其功能是像洗牌一样将列表打乱。 8\. 利用筛法找出小于等于 n 的所有质数。基本思想是:首先创建从 2 到 n 的数值列表;然 后将列表的第一个数显示输出(是质数),并从列表中删除该数的所有倍数。重复以上过程 直至列表为空。例如,如果 n 为 10,则初始列表为[2, 3, 4, 5, 6, 7, 8, 9, 10]。输出 2,并删除 2、4、6、8、10。现在列表为[3, 5, 7, 9]。输出 3,删除 3、9。现在列表为[5, 7]。输出 5, 并删除 5。最后对[7]输出 7,删除 7。至此列表为空,程序结束。 9\. 设计一个学生信息管理系统。每个学生包括学号、姓名、年龄等信息,大量学生数据存 储在文件中。程序开始后向用户显示一个操作菜单,包括向数据文件增加数据项、删除数据 项、查找数据项和退出等功能。用户选择菜单项后执行相应功能,执行完毕回到菜单界面。 11\. 利用链表来实现堆栈数据结构。 12\. 分别利用普通列表和链表来实现队列数据结构。
';