python基础面试
1 请用自己的算法, 按升序合并如下两个list, 并去除重复的元素:
list1 = [2, 3, 8, 4, 9, 5, 6]
list2 = [5, 6, 10, 17, 11, 2]
答案:
(1)自己的算法?
for x in list1:
for y in list2:
if x == y:
list2.remove(y)
list1 = list1+list2
lsit1 = list1.sort()
(2)
list1[0:0]=list2 或者 list1.extend(list2)
注意:列表方法sort()改变是列表本身序列,没有返回值,sorted函数是生成一个新的有返回值
list1.extend(list2)
print(sorted(set(list1)))
对比一下dict中 items 与 iteritems
items会一次性取出所有的值,并以列表返回,iteritems返回的是生成器,通过迭代取出里面的值,一般在数据量大的时候,iteritems会比items效率高些
Python中如何去除list中重复的数据
方法一:
使用set函数
方法二:
a = [1,2,3,4,5,56,6,7,8,8,9]
b = {}
b= b.fromkeys(a)
c= list(b)
请实现字符串翻转5种方案
Python实现
方法一:
def reverse (s):
rt = ''
for i in range(len(s)-1, -1, -1):
rt += s[i]
return rt
方法二:
def reverse2 (s):
li = list(s)
li.reverse()
rt = "".join(li)
return rt
方法三:
def reverse3 (s):
return s[::-1]
方法四:
def reverse4 (s):
return "".join(reversed(s))
方法五:
from functools import reduce
def reverse5 (s):
return reduce(lambda x,y:y+x,s)
注意:方法一和方法二以及方法三一般人都能写,四和五比较新颖
在没有第三个参数的情况下,交换2个变量的值
方案一:a,b = b,a
方案二:a = a + b
b = a - b
a = a - b
实现将2个元组合并成一个字典
a = ('a','b','c','d')
b = (1,2,3,4)
dict(map(lambda x,y:[x,y],a,b))
二:
dict(zip(a,b))
要求写出一个单例程序
class Dog(object):
__first_new = True
__instance = None
def __new__(cls):
if cls.__first_new:
cls.__instance = object.__new__(cls)
cls.__first_new = False
return cls.__instance
else:
return cls.__instance
a = Dog()
b = Dog()
Python和c和Java的对比
python比较容易学习,语法简单python的库非常丰富,开发速度快,但是python脚本运行效率低,不适合做运行效率要求高的程序,java的语法比较严格,学习的曲线比较长,开发框架很强大,比较适合企业级的应用,和python\java相比,c是最古老的,c是为了代替汇编语言才出现的,一般用c做操作系统方面的开发,linux就是。
有用过with statement吗?它的好处是什么?
是否遇到过python的模块间循环引用的问题,如何避免它?
这是代码结构设计的问题,模块依赖和类依赖 如果老是觉得碰到循环引用,很可能是模块的分界线划错地方了。可能是把应该在一起的东西硬拆开了,可能是某些职责放错地方了,可能是应该抽象的东西没抽象
使用 “__all__” 白名单开放接口 尽量避免 import
用最简单的方法将二维数组a = [[1,2,3],][4,5,6],][7,8,9],[11,12,13]]变成一维数组a = [1,2,3,4,5,6,7,8,9,11,12,13]
方法一
列表推导式
a1 = [y for x in a for y in x]
方法二
from compiler.ast import flatten
xx = flatten(a)
请阐述垃圾回收机制的原理
要是被问到就这么和面试官答保你必过:
python的垃圾回收机制和Java一样是自动回收没有用的资源的,采用的是引用计数为主,分带回收为辅的策略,
在python中当程序的引用计数为0的时候,Python就会对它进行回收处理释放资源,也就是引用计数为主,因为程序
的引用每次都会进行记录统计,所以引用计数会占用大量的资源,导致资源无法释放,当出现这种情况下,
python就会把所有循环引用的对象放在一个链表当中,这个链表称为0代,当引用计数器达到一定的阀值时,
Python会对0代的链条进行检查,标出没用的引用对象进行回收释放内存,将剩余的引用对象重新生成一个新的
链条即1代链条,当引用计数器达到一定的阀值,python处理1代的回收对象,将剩余的对象重新生成一个新的链条
即2代链条,当2代处理后如果有对象没有回收,该对象就放在2代链条上