华为软件开发部门面试指南及答案.docxVIP

  • 1
  • 0
  • 约6.55千字
  • 约 18页
  • 2026-03-12 发布于福建
  • 举报

第PAGE页共NUMPAGES页

2026年华为软件开发部门面试指南及答案

一、编程能力测试(共5题,每题10分,总分50分)

1.题目:请编写一个函数,实现快速排序算法。输入一个整数数组,输出排序后的数组。要求在函数中处理边界条件,如空数组或单元素数组。

python

defquick_sort(arr):

你的代码

答案:

python

defquick_sort(arr):

ifnotarrorlen(arr)=1:

returnarr

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

left=[xforxinarrifxpivot]

middle=[xforxinarrifx==pivot]

right=[xforxinarrifxpivot]

returnquick_sort(left)+middle+quick_sort(right)

解析:快速排序是一种分治算法,通过选择一个基准值(pivot),将数组分为小于、等于和大于基准值的三部分,然后递归地对小于和大于基准值的部分进行排序。边界条件处理是确保算法的正确性。

2.题目:请编写一个函数,实现二分查找算法。输入一个有序整数数组和一个目标值,输出目标值在数组中的索引。如果目标值不存在,返回-1。

python

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档