练习题汇总(一)

 1、

 1  #一行代码实现1-100的和  
 2 
 3 #Python
 4 s = sum(range(101))
 5 s = sum(i for i in range(101))
 6 
 7 
 8 #java(不是一行)
 9 
10int s = 0;
11for(int i =1 ;i<101;i++){
12  s += i;
13 }
14 System.out.println(s);
15   

 

2、

1 #Python标准库
2 
3 requests 
4 BeautifulSoup 
5 re 
6 json 
7 threading
8 os
9 flask

 

3、

1 #列表去重
2 
3 s = [1,2,3,2,3,3,7]
4 print(list(set(s)))

 

4、

 1 '''
 2 参数 args, kwargs
 3 
 4 args 代表 元祖
 5 kwargs 传入的字典 
 6 '''
 7 
 8 def arg(*args,**kwargs):
 9     return args,kwargs
10 print(arg(1, 2, 3, a=1, b=3))
11 
12 #((1, 2, 3), {'a': 1, 'b': 3})

 

 

5、

 

1 '''
2 一行代码将[[1,2],[3,4],[5,6]]展开,得出[1,2,3,4,5,6]
3 '''
4 a=[[1, 2], [3, 4], [5, 6]]
5 print( [j for i in a for j in i])

 

6、

1 """
2 进程是资源(CPU、内存等)分配的基本单位,它是程序执行时的一个实例。
3 线程是程序执行时的最小单位,它是进程的一个执行流。
4 进程有自己的独立地址空间,每启动一个进程,系统就会为它分配地址空间,建立数据表来维护代码段、堆栈段和数据段,这种操作非诚昂贵。
5 【所以各个进程有自己的地址空间,彼此互相不打扰】
6 线程是共享进程中的数据的,使用相同的地址空间,因此CPU切换一个线程的花费比进程要小很多,同时创建一个线程的开销也比进程要小很多。
7 """

 

7、

 1 """
 2 垃圾回收
 3 (1)引用计数
 4 import sys
 5 str1='hello world'
 6 print(sys.getrefcount(str1)) #在python解释器下运行,为2  创建一次,调用一次
 7 (2)分代计数
 8 Python默认定义了三代对象集合,索引数越大,对象存活时间越长
 9 Python中使用了某些启发式算法(heuristics)来加速垃圾回收。
10 【例如,越晚创建的对象更有可能被回收。对象被创建之后,垃圾回收器会分配它们所属的代(generation)。每个对象都会被分配一个代,而被分配更年轻代的对象是优先被处理的。】
11 (3)引用循环
12 垃圾回收器会定时寻找这个循环,并将其回收。
13 举个例子,假设有两个对象o1和o2,而且符合o1.x == o2和o2.x == o1这两个条件。如果o1和o2没有其他代码引用,那么它们就不应该继续存在。但它们的引用计数都是1。
14 """

 

8、

 1     a = [1, 2, 3, 4]
 2     b = [4, 3, 5, 6]
 3     # 求交集
 4     cj1 = [i for i in a if i in b]
 5     cj2 = list(set(a).intersection(set(b)))
 6     print(cj1)
 7     print(cj2)
 8     #求差集
 9     cj1 = list(set(a).difference(set(b)))
10     cj2 = [i for i in a if i not in b]
11     print(cj1)
12     print(cj2)
13     # 求并集
14     cj1 = list(set(a).union(set(b)))
15     cj2 = list(set([i for i in a+b]))
16     print(cj1)
17     print(cj2)

 

9、

1 """
2 1.装饰器的原理及为什么要用装饰器
3 2. 装饰器的基本用法
4 3. 带参数的装饰器
5 4. 被装饰的函数有返回值怎么处理
6 5. 多个装饰器的执行顺序
7 6. 装饰类的装饰器
8 """

 

posted @ 2022-03-08 20:31  菜小鱼~  阅读(28)  评论(0编辑  收藏  举报