面试中常见的算法题和其python实现

在面试中,常见的算法题包括排序算法、查找算法、动态规划、贪心算法等。以下是一些常见算法题及其Python实现示例:

1. 快速排序(Quick Sort):

  • 题目描述:给定一个数组,使用快速排序算法对数组进行排序。
  • 示例代码:
python 复制代码
   def quickSort(arr):
       if len(arr) <= 1:
           return arr
       pivot = arr[len(arr) // 2]
       left = [x for x in arr if x < pivot]
       middle = [x for x in arr if x == pivot]
       right = [x for x in arr if x > pivot]
       return quickSort(left) + middle + quickSort(right)

2. 二分查找(Binary Search):

  • 题目描述:给定一个已排序数组和一个目标值,使用二分查找算法在数组中查找目标值的索引。
  • 示例代码:
python 复制代码
   def binarySearch(nums, target):
       left, right = 0, len(nums) - 1
       while left <= right:
           mid = (left + right) // 2
           if nums[mid] == target:
               return mid
           elif nums[mid] < target:
               left = mid + 1
           else:
               right = mid - 1
       return -1

3. 最长递增子序列(Longest Increasing Subsequence):

  • 题目描述:给定一个无序的整数数组,找到其中最长的递增子序列的长度。
  • 示例代码:
python 复制代码
   def lengthOfLIS(nums):
       if not nums:
           return 0
       dp = [1] * len(nums)
       for i in range(len(nums)):
           for j in range(i):
               if nums[i] > nums[j]:
                   dp[i] = max(dp[i], dp[j] + 1)
       return max(dp)

4. 零钱兑换(Coin Change):

  • 题目描述:给定一些不同面额的硬币和一个总金额,计算出凑成总金额所需的最少硬币数量。
  • 示例代码:
python 复制代码
   def coinChange(coins, amount):
       dp = [float('inf')] * (amount + 1)
       dp[0] = 0
       for i in range(1, amount + 1):
           for coin in coins:
               if i >= coin:
                   dp[i] = min(dp[i], dp[i-coin] + 1)
       return dp[amount] if dp[amount] != float('inf') else -1
相关推荐
Tisfy2 分钟前
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小
算法·leetcode·题解·排序·最小次小值
A先生的AI之旅6 分钟前
2026-1-30 LingBot-VA解读
人工智能·pytorch·python·深度学习·神经网络
Learn Beyond Limits7 分钟前
文献阅读:A Probabilistic U-Net for Segmentation of Ambiguous Images
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·ai
丝瓜蛋汤7 分钟前
微调生成特定写作风格助手
人工智能·python
-To be number.wan10 分钟前
Python数据分析:Matplotlib 绘图练习
python·数据分析·matplotlib
naruto_lnq12 分钟前
Python生成器(Generator)与Yield关键字:惰性求值之美
jvm·数据库·python
m0_7369191018 分钟前
编译器命令选项优化
开发语言·c++·算法
Stream_Silver20 分钟前
【Agent学习笔记1:Python调用Function Calling,阿里云API函数调用与DeepSeek API对比分析】
开发语言·python·阿里云
naruto_lnq25 分钟前
C++中的工厂方法模式
开发语言·c++·算法
没事儿写两篇28 分钟前
Python 包管理工具-uv
python·uv·开源包管理工具