2026年工程师面试题及答案详解.docxVIP

  • 2
  • 0
  • 约5.45千字
  • 约 16页
  • 2026-05-17 发布于福建
  • 举报

第PAGE页共NUMPAGES页

2026年工程师面试题及答案详解

一、编程基础(5题,每题10分,共50分)

1.题目:

请用Python编写一个函数,实现快速排序算法。输入一个无序列表,输出排序后的列表。要求在函数中处理空列表和单元素列表的情况。

答案:

python

defquick_sort(arr):

iflen(arr)=1:

returnarr

pivot=arr[len(arr)//2]

left=[xforxinarrifxpivot]

middle=[xforxinarrifx==pivot]

right=[xforxinarrifxpivot]

returnquick_sort(left)+middle+quick_sort(right)

解析:

快速排序是分治算法的经典实现。核心思想是选择一个基准值(pivot),将数组分为小于、等于、大于三部分,然后递归排序左右子数组。函数首先处理边界情况(空列表或单元素列表),然后选择中位数作为基准值,避免最坏情况(已排序数组)。时间复杂度平均为O(nlogn),最坏为O(n2)。

2.题目:

请用Java实现一个单例模式(双重校验锁),确保全局只有一个实例被创建。

答案:

java

publicclassS

文档评论(0)

1亿VIP精品文档

相关文档