100道Python常见面试题

275 篇文章 10 订阅

Python现在已经成为最热门的编程语言之一,IEEE Spectrum统计数据显示,Python无论从普及度和生态规模都已位居编程语言第一,而且相关职位也越来越多,无论数据岗、测试岗亦或开发岗都对Python技能有着高度的需求。

在这里插入图片描述
从求职来看,无论笔试还是面试,想要顺利通过,刷题都是最好的路径,python岗位更是如此。

之前在github上看到一个项目,作者收集了接近100个常见的Python面试题,涉及语言特性、操作系统、数据库、web、数据结构等等,非常详细。

部分面试题清单:

在这里插入图片描述
下面是部分面试题:

1、台阶问题/斐波那契

一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。

fib = lambda n: n if n <= 2 else fib(n - 1) + fib(n - 2)

第二种记忆方法

def memo(func):    cache = {}    def wrap(*args):        if args not in cache:            cache[args] = func(*args)        return cache[args]    return wrap @memodef fib(i):    if i < 2:        return 1    return fib(i-1) + fib(i-2)

第三种方法

def fib(n):    a, b = 0, 1    for _ in xrange(n):        a, b = b, a + b    return b

2、变态台阶问题

一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。

fib = lambda n: n if n < 2 else 2 * fib(n - 1)

3、矩形覆盖

我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?

第2n个矩形的覆盖方法等于第2(n-1)加上第2*(n-2)的方法。

f = lambda n: 1 if n < 2 else f(n - 1) + f(n - 2)

4、杨氏矩阵查找

在一个m行n列二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

使用Step-wise线性搜索。

def get_value(l, r, c):    return l[r][c]def find(l, x):    m = len(l) - 1    n = len(l[0]) - 1    r = 0    c = n    while c >= 0 and r <= m:        value = get_value(l, r, c)        if value == x:            return True        elif value > x:            c = c - 1        elif value < x:            r = r + 1    return False

5、去除列表中的重复元素

用集合

list(set(l))

用字典

l1 = ['b','c','d','b','c','a','a']l2 = {}.fromkeys(l1).keys()print l2

用字典并保持顺序

l1 = ['b','c','d','b','c','a','a']l2 = list(set(l1))l2.sort(key=l1.index)print l2

列表推导式

l1 = ['b','c','d','b','c','a','a']l2 = [][l2.append(i) for i in l1 if not i in l2]

sorted排序并且用列表推导式.

l = ['b','c','d','b','c','a','a'][single.append(i) for i in sorted(l) if i not in single]print single

关于Python技术储备

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

五、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。


这份完整版的Python全套学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

Python资料、技术、课程、解答、咨询也可以直接点击下面名片,添加官方客服斯琪

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 什么是Python? Python是一种高级编程语言,它是一种解释性语言,可以在各种操作系统上运行。 2. Python的特点是什么? Python具有简单、易于学习、易于阅读、易于维护、可扩展性强、可移植性好等特点。 3. Python中的缩进是什么意思? Python使用缩进来表示代码块,而不是使用花括号或关键字来表示。缩进必须是4个空格或一个制表符。 4. 如何在Python中定义一个变量? 在Python中定义变量时,不需要指定变量的类型。只需要使用一个等号来给变量赋值即可。 例如,x = 5 5. Python中有哪些数据类型? Python中有整数、浮点数、复数、字符串、布尔值、列表、元组、字典等数据类型。 6. 如何在Python中定义一个函数? 在Python中定义一个函数,需要使用def关键字,后面跟着函数的名称和参数列表。函数体需要缩进。 例如,def functionName(parameter1, parameter2): 7. Python中的if语句是怎样的? 在Python中,if语句使用冒号来表示代码块的开始。if语句的条件可以是任何返回布尔值的表达式。 例如,if x > 5: 8. Python中的for循环是怎样的? 在Python中,for循环可以遍历任何可迭代对象,例如列表、元组、字符串等。在循环内部,可以使用break和continue关键字来控制循环的执行。 例如,for item in myList: 9. Python中的while循环是怎样的? 在Python中,while循环使用条件表达式来控制循环的执行。在循环内部,可以使用break和continue关键字来控制循环的执行。 例如,while x > 0: 10. 如何在Python中读取文件? 在Python中,可以使用open()函数打开文件,并使用read()函数读取文件中的内容。 例如,file = open("filename.txt", "r") content = file.read() 11. 如何在Python中写入文件? 在Python中,可以使用open()函数打开文件,并使用write()函数将内容写入文件。 例如,file = open("filename.txt", "w") file.write("Hello World") 12. 如何在Python中创建一个列表? 在Python中,可以使用中括号来创建一个列表。在列表中可以包含任何类型的数据。 例如,myList = [1, 2, 3, "Hello World"] 13. 如何在Python中创建一个字典? 在Python中,可以使用花括号来创建一个字典。字典由键值对组成,每个键值对之间用逗号隔开。 例如,myDict = {"name": "Tom", "age": 20} 14. 如何在Python中使用模块? 在Python中,可以使用import语句导入模块。导入模块后,可以使用模块中的函数和变量。 例如,import math print(math.pi) 15. 如何在Python中处理异常? 在Python中,可以使用try/except语句来处理异常。在try块中执行代码,如果出现异常,则执行except块中的代码。 例如, try: x = 1 / 0 except ZeroDivisionError: print("Error: Division by zero") 16. 如何在Python中调用函数? 在Python中,可以使用函数名和参数列表来调用函数。函数可以返回任何类型的值。 例如,myFunction(parameter1, parameter2) 17. 如何在Python中定义一个类? 在Python中,可以使用class关键字来定义一个类。类包含属性和方法。 例如, class MyClass: def __init__(self, parameter1, parameter2): self.parameter1 = parameter1 self.parameter2 = parameter2 def myMethod(self): print("Hello World") 18. 如何在Python中使用继承? 在Python中,可以使用class关键字来定义一个类,并使用继承来派生子类。子类可以使用父类的属性和方法。 例如, class MySubClass(MyClass): def __init__(self, parameter1, parameter2, parameter3): super().__init__(parameter1, parameter2) self.parameter3 = parameter3 19. 如何在Python中使用装饰器? 在Python中,装饰器是一种特殊的函数,可以用来修改其他函数的行为。装饰器通常用于添加日志、验证、缓存等功能。 例如, def myDecorator(func): def wrapper(): print("Before function call") func() print("After function call") return wrapper @myDecorator def myFunction(): print("Hello World") 20. 如何在Python中使用生成器? 在Python中,生成器是一种特殊的函数,可以用来生成序列。生成器可以一次生成一个值,并在下一次请求时生成下一个值。 例如, def myGenerator(): yield 1 yield 2 yield 3 for i in myGenerator(): print(i)

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值