川石教育
全国咨询热线:136-9172-9932
  1. 首页 > 资讯与干货 > 常见问题

python测试开发面试题

作者:川石学院 日期:2021-12-01 15:05:26 点击数:

python测试开发面试题,软件测试人员必码!

python测试开发面试题(图1)

  必考面试题

  •   如何去除列表中的重复元素

  •   八大排序算法合集

  •   斐波那契数列的python实现

  •   如何对字符串进行反转

  •   如何对单词反转

  •   统计字符串中每个字母出现的次数

  •   对某英文文章的单词,进行词数统计

  •   python的字典合并

  •   python的赋值、浅拷贝和深拷贝的区别

  •   返回字符串中第一个不重复的字母和位置

  经常会问到的面试题

  •   如何不通过循环,输出1到100

  •   两个列表如何生成一个对应的字典

  •   字典排序

  •   判断一个字符串中的括号是不是成对出现的

  •   一行代码实现字典的key和value反转

  •   python如何实现单例模式

  •   为什么模块称为天然的单例模式?

  •   Python处理排列组合

  •   将某个数字列表中的元素拼成一个最大的数

  偶尔会问到的面试题

  •   丑数计算?

  •   如何快速找到多个字典的公共键?

  •   python的socket编程

  •   求一个数字列表里,相邻两数乘积最高的值,及这两个数分别是多少?

  •   如何求字符串例的最长回文子串?

  精讲5题

  1、如何去除列表中的重复元素 【热度:⭐️⭐️⭐️⭐️⭐️】

  【题目】给出一个列表:lis = [4, 2, 1, 3, 4, 2, 3, 1, 3, 2, 2, 2],去除列表中的重复元素。

  lis = [4, 2, 1, 3, 4, 2, 3, 1, 3, 2, 2, 2]

  # 解法1: 利用set去重,会改变列表顺序

  lis1 = list(set(lis))

  # 解法2:

  lis2 = []

  for i in lis:

  if i not in lis2:

  lis2.append(i)

  2、八大排序算法合集 -- 冒泡排序 【热度:⭐️⭐️⭐️⭐️⭐️】

  def bubble_sort(lists):

  '''

  冒泡排序(升序)【稳定排序】

  原理:

  1、从第一个元素开始,开始依次对相邻的两个元素进行比较,当后面的元素大于前面的元素时,交换二者位置;

  2、进行一轮比较之后,最大的元素将在序列尾部(最后一位);

  3、然后对(n-1)个元素再进行第二轮比较,最大元素将在序列倒数第二位;

  4、重复该过程,直至只剩下最后一个元素为止,最后的元素就是最小值,排在序列首位

  以 list = [5, 4, 2, 1, 3] 为例:

  第一轮排序: [4, 2, 1, 3, 5]

  第二轮排序: [2, 1, 3, 4, 5]

  第三轮排序: [1, 2, 3, 4, 5]

  时间复杂度: O(n) ~ O(n**2) 平均:O(n**2)

  空间复杂度: O(1)

  :param lists:

  :return lists:

  '''

  for i in range(len(lists)-1):

  for j in range(len(lists)-i-1):

  if lists[j] > lists[j+1]:

  lists[j], lists[j+1] = lists[j+1], lists[j]

  return lists

  # 调用冒泡排序

  bubble_sort_list = bubble_sort(lis)

  print(bubble_sort_list)

  3、斐波那契数列的python实现 【热度:⭐️⭐️⭐️⭐️⭐️】

  【题目】 斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、…… 基于python用多种方式,生成费波拉契数列。

  # (1)递归法 返回 idx 位的数值,缺点:只能返回某个值

  def fib_recursion(idx):

  if idx <= 2:

  return 1

  else:

  return fib_recursion(idx-1) + fib_recursion(idx-2)

  # (2)迭代法 返回 idx 位之前的fib数列

  def fib_iteration(idx):

  lst = []

  n,a,b = 0,0,1

  while n < idx:

  lst.append(b)

  a,b = b, a+b

  n += 1

  return lst

  # (3)生成器法

  def fib_generator(idx):

  n,a,b = 0,0,1

  while n < idx:

  yield b

  a,b = b, a+b

  n += 1

  if __name__ == '__main__':

  idx = 6

  numb = fib_recursion(idx)

  print(numb)

  lst = fib_iteration(idx)

  print(lst)

  lst1 = fib_generator(idx)

  print(list(lst1))

  4、如何对字符串进行反转 【热度:⭐️⭐️⭐️⭐️⭐️】

  【题目】要求不使用任何系统方法,且时间复杂度最小

  def reverse_str(input_str):

  ch=list(input_str)

  lens=len(ch)

  i=0

  j=lens-1

  while i < j:

  tmp= ch[i]

  ch[i] =ch[j]

  ch[j]=tmp

  i+=1

  j-=1

  return ''.join(ch)

  #tips 假如可以使用系统方法,如何实现?

  new_str = old_str[::-1]

  5、返回字符串中第一个不重复的字母和位置 【热度:⭐️⭐️⭐️⭐️⭐️】

  def first_char(str):

  d = {}

  for i in range(len(str)):

  # 累计字符的出现次数

  if str[i] in d:

  d[str[i]] += 1

  # 只出现一次,key对应的value就记1次

  else:

  d[str[i]] = 1

  for i in range(len(str)):

  if d[str[i]] == 1:

  return '第一个不重复的字符串是{},索引是{}'.format(str[i], i)

  return "没有不重复的字符串"

  if __name__ == '__main__':

  s = "wwqqoogg"

  res = first_char(s)

  print(res)


相关文章
  • 亚马逊运营成功转行软件测试,薪资13K表示很满意!2021-12-01 15:05:26
  • 西安川石的兰朋友喊你来当他的学弟学妹啦!2021-12-01 15:05:26
  • 国外的月亮也不一定比国内测试猿的年薪美~2021-12-01 15:05:26
  • 建筑工程专业朱同学成功转行为软件测试人!2021-12-01 15:05:26
  • 财务管理专业转行软件测试月薪甩会计几条街!2021-12-01 15:05:26
  • 只有技术沉淀才能成功上岸,深圳就业薪资13K!2021-12-01 15:05:26
  • 薪资11K!实现自我价值,从掌握一门IT技术开始...2021-12-01 15:05:26
  • 文科生转行软件测试照样拿下高薪15K!2021-12-01 15:05:26
  • 恭喜罗同学喜提19.5K,成功入行软件测试!2021-12-01 15:05:26
  • 毕业1年,迷茫的他最终选择转行软件测试2021-12-01 15:05:26