小甲鱼Python第012讲列表:一个打了激素的数组3| 课后测试题及参考答案

测试题:
   
0. 注意,这道题跟上节课的那道题有点儿不同,回答完请上机实验或参考答案。

1 old = [1, 2, 3, 4, 5]
2 new = old
3 old = [6]
4 print(new)

如果不上机操作,你觉得会打印什么内容?

  [1,2,3,4,5]  
    
1. 请问如何将下边这个列表的'小甲鱼'修改为'小鱿鱼'?

1 list1 = [1, [1, 2, ['小甲鱼']], 3, 5, 8, 13, 18]
1 list1 = [1, [1, 2, ['小甲鱼']], 3, 5, 8, 13, 18]
2 list1[1][2][0]='小鱿鱼'
3 print(list1)

2. 要对一个列表进行顺序排序,请问使用什么方法?

列表名.sort()

1 num=[1,4,5,6,72,3,5,2,4,45,34]
2 num.sort()
3 print(num)

3. 要对一个列表进行逆序排序,请问使用什么方法?

  正序排序:列表名.sort()

  逆序排序:列表名.reverse()

1 num=[1,4,5,6,72,3,5,2,4,45,34]
2 num.sort()
3 num.reverse()
4 print(num)

4. 列表还有两个内置方法没给大家介绍,不过聪明的你应该可以自己摸索使用的门道吧:copy() 和 clear()

  列表名.copy()==切片拷贝(list = list[:]):

1 list1 = [1, [1, 2, ['小甲鱼']], 3, 5, 8, 13, 18]
2 list2 = list1.copy()
3 print(list2)
4 list3 = list1[:]
5 print(list3)

  列表名.clear():用于清空列表的元素,但是,清空完列表后仍然还在,一个空列表。

1 list1 = [1, [1, 2, ['小甲鱼']], 3, 5, 8, 13, 18]
2 list2 = list1.clear()
3 print(list2)  

5. 你有听说过列表推导式或列表解析吗?

  列表推导式(List comprehensions)也叫列表解析,灵感取自函数式编程语言 Haskell。Ta 是一个非常有用和灵活的工具,可以用来动态的创建列表,语法如:[有关A的表达式 for A in B]

  看表达式: 

    [ i*i for i in range(10) ] =[x**2 for x in range(10)]

  等同于:

1 list1 = []
2 for x in range(10):
3     list1.append(x**2)
4 print(list1)

  会打印什么内容?    ---->[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]


问题:请先在 IDLE 中获得下边列表的结果,并按照上方例子把列表推导式还原出来。

list1 = [(x, y) for x in range(10) for y in range(10) if x%2==0 if y%2!=0]

还原过程:

1 list = []
2 for x in range(10):
3     for y in range(10):
4         if x%2 ==0:
5             if y%2 != 0:
6                 list.append((x,y))
7 print(list)

6. 活学活用:请使用列表推导式补充被小甲鱼不小心涂掉的部分
  

1 list1 = ['1.Just do it','2.一切皆有可能','3.让编程改变世界','4.Impossiable is Nothing']
2 list2 = ["4.阿迪达斯","2.李宁","3.鱼C","1.耐克"]
3 list3 = [name + '' + slogan[2:] for slogan in list1 for name in list2 if slogan[0] == name[0]]
4 for each in list3:
5     print(each)

7. 请写下这一节课你学习到的内容:格式不限,回忆并复述是加强记忆的好方式!

  正序排序:列表名.sort()

  逆序排序:列表名.reverse()

  列表名.copy()==切片拷贝(list = list[:]):

  列表名.clear():用于清空列表的元素,但是,清空完列表后仍然还在,一个空列表。

列表推导式(List comprehensions)也叫列表解析,灵感取自函数式编程语言 Haskell。Ta 是一个非常有用和灵活的工具,可以用来动态的创建列表,语法如:[有关A的表达式 for A in B]

  看表达式: 

    [ i*i for i in range(10) ] =[x**2 for x in range(10)]

第六题!!

3 list3 = [name + ':' + slogan[2:] for slogan in list1 for name in list2 if slogan[0] == name[0]]

 

原文地址:https://www.cnblogs.com/IT-NXXB/p/12852549.html