当前位置: 首页 > news >正文

Python面试题【数据结构和算法部分101-130】

Python面试题【数据结构和算法部分101-130】

  • Python面试题【数据结构和算法部分101-130】

Python面试题【数据结构和算法部分101-130】

  1. 问题:如何在Python中实现二分查找?
    答案:
    def binary_search(arr, target):low, high = 0, len(arr) - 1while low <= high:mid = (low + high) // 2if arr[mid] == target:return midelif arr[mid] < target:low = mid + 1else:high = mid - 1return -1
  1. 问题:Python中如何实现链表?
    答案:
    class ListNode:def __init__(self, value=0, next=None):self.value = valueself.next = next
  1. 问题:如何在Python中反转链表?
    答案:
    def reverse_list(head):prev = Nonecurrent = headwhile current:next_node = current.nextcurrent.next = prevprev = currentcurrent = next_nodereturn prev
  1. 问题:Python中的栈和队列有什么区别?
    答案:
    栈是一种后进先出(LIFO)的数据结构,而队列是一种先进先出(FIFO)的数据结构。

  2. 问题:如何在Python中实现一个栈?
    答案:

    class Stack:def __init__(self):self.items = []def push(self, item):self.items.append(item)def pop(self):return self.items.pop()def is_empty(self):return not self.items
  1. 问题:如何在Python中实现一个队列?
    答案:
    class Queue:def __init__(self):self.items = []def enqueue(self, item):self.items.insert(0, item)def dequeue(self):return self.items.pop()def is_empty(self):return not self.items
  1. 问题:解释Python中的堆(Heap)及其用途。
    答案:
    堆是一种特殊的完全二叉树。所有的父节点都大于或等于(最大堆)或小于或等于(最小堆)它们的子节点。堆常用于实现优先队列。

  2. 问题:如何在Python中找到列表中的第k个最大元素?
    答案:

    import heapqdef find_kth_largest(nums, k):return heapq.nlargest(k, nums)[-1]
  1. 问题:解释Python中的哈希表(Hash Table)及其用途。
    答案:
    哈希表是一种使用哈希函数组织数据,以支持快速插入和搜索的数据结构。Python中的字典(dict)是哈希表的一个实例。

  2. 问题:如何在Python中检测循环链表?
    答案:

    def has_cycle(head):slow, fast = head, headwhile fast and fast.next:slow = slow.nextfast = fast.next.nextif slow == fast:return Truereturn False
  1. 问题:如何在Python中实现图的深度优先遍历?
    答案:
    def dfs(graph, start, visited=None):if visited is None:visited = set()visited.add(start)print(start)for next_node in graph[start] - visited:dfs(graph, next_node, visited)return visited
  1. 问题:如何在Python中实现图的广度优先遍历?
    答案:
    from collections import dequedef bfs(graph, start):visited = set()queue = deque([start])while queue:vertex = queue.popleft()if vertex not in visited:visited.add(vertex)queue.extend(graph[vertex] - visited)return visited
  1. 问题:如何在Python中检查两个字符串是否是变位词(anagrams)?
    答案:
    from collections import Counterdef are_anagrams(str1, str2):return Counter(str1) == Counter(str2)
  1. 问题:如何在Python中实现快速排序?
    答案:
    def quicksort(arr):if len(arr) <= 1:return arrpivot = 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)
  1. 问题:如何在Python中实现归并排序?
    答案:
    def merge_sort(arr):if len(arr) > 1:mid = len(arr) // 2L = arr[:mid]R = arr[mid:]merge_sort(L)merge_sort(R)i = j = k = 0while i < len(L) and j < len(R):if L[i] < R[j]:arr[k] = L[i]i += 1else:arr[k] = R[j]j += 1k += 1while i < len(L):arr[k] = L[i]i += 1k += 1while j < len(R):arr[k] = R[j]j += 1k += 1return arr
  1. 问题:如何在Python中找到数组中的最长连续序列?
    答案:
    def longest_consecutive(nums):num_set = set(nums)longest = 0for n in nums:if n - 1 not in num_set:length = 0while n + length in num_set:length += 1longest = max(longest, length)return longest
  1. 问题:在Python中如何实现动态规划解决方案?
    答案:
    动态规划是一种将复杂问题分解为更小子问题的算法设计技术。通常通过填充一个表格来解决,并将子问题的解存储在表格中供后续引用,以避免重复计算。

  2. 问题:如何在Python中实现二叉树?
    答案:

    class TreeNode:def __init__(self, value):self.value = valueself.left = Noneself.right = None
  1. 问题:如何在Python中检测二叉树是否平衡?
    答案:
    def is_balanced(root):def check(node):if node is None:return 0left_height = check(node.left)if left_height == -1:return -1right_height = check(node.right)if right_height == -1:return -1if abs(left_height - right_height) > 1:return -1return max(left_height, right_height) + 1return check(root) != -1
  1. 问题:如何在Python中找到二叉搜索树中第k小的元素?
    答案:
    def kth_smallest(root, k):stack = []while True:while root:stack.append(root)root = root.leftroot = stack.pop()k -= 1if not k:return root.valueroot = root.right
  1. 问题:如何在Python中实现堆排序算法?
    答案:
    import heapqdef heap_sort(iterable):h = []for value in iterable:heapq.heappush(h, value)return [heapq.heappop(h) for _ in range(len(h))]
  1. 问题:在Python中如何找出数组中的重复数字?
    答案:
    def find_duplicates(nums):duplicates = set()seen = set()for num in nums:if num in seen:duplicates.add(num)seen.add(num)return list(duplicates)
  1. 问题:描述Python中的双端队列(deque)及其用途。
    答案:
    双端队列(deque)是一种具有队列和栈的性质的数据结构。在collections模块中,deque是一个双端队列的实现,允许我们从前面或后面添加或删除元素。

  2. 问题:如何在Python中实现二叉树的层序遍历?
    答案:

    from collections import dequedef level_order_traversal(root):if not root:return []queue = deque([root])result = []while queue:level_size = len(queue)current_level = []for _ in range(level_size):node = queue.popleft()current_level.append(node.value)if node.left:queue.append(node.left)if node.right:queue.append(node.right)result.append(current_level)return result
  1. 问题:如何在Python中实现前缀树(Trie)?
    答案:
    class TrieNode:def __init__(self):self.children = {}self.is_end_of_word = Falseclass Trie:def __init__(self):self.root = TrieNode()def insert(self, word):node = self.rootfor char in word:if char not in node.children:node.children[char] = TrieNode()node = node.children[char]node.is_end_of_word = True
  1. 问题:如何在Python中找到数组的所有子集?
    答案:
    def subsets(nums):result = [[]]for num in nums:result += [curr + [num] for curr in result]return result
  1. 问题:如何在Python中找到无序数组中的中位数?
    答案:
    import heapqdef find_median(nums):min_heap = []max_heap = []for num in nums:heapq.heappush(max_heap, -heapq.heappushpop(min_heap, num))if len(max_heap) > len(min_heap):heapq.heappush(min_heap, -heapq.heappop(max_heap))if len(min_heap) > len(max_heap):return min_heap[0]return (min_heap[0] - max_heap[0]) / 2.0
  1. 问题:描述Python中的广度优先搜索(BFS)算法。
    答案:
    广度优先搜索(BFS)是一种遍历或搜索树或图的算法,它从根节点开始,逐层遍历所有节点,每次遍历同一层的所有节点。

  2. 问题:如何在Python中找到字符串中的最长不含重复字符的子串?
    答案:

    def length_of_longest_substring(s):char_map = {}left = 0max_length = 0for right, char in enumerate(s):if char in char_map and char_map[char] >= left:left = char_map[char] + 1char_map[char] = rightmax_length = max(max_length, right - left + 1)return max_length
  1. 问题:如何在Python中实现动态数组?
    答案:
    动态数组可以通过内置的list类型实现,它在底层自动扩展其大小。

相关文章:

Python面试题【数据结构和算法部分101-130】

Python面试题【数据结构和算法部分101-130】 Python面试题【数据结构和算法部分101-130】 Python面试题【数据结构和算法部分101-130】 问题&#xff1a;如何在Python中实现二分查找&#xff1f; 答案&#xff1a; def binary_search(arr, target):low, high 0, len(arr) - 1…...

Django中的日志处理

日志处理 1.日志级别 级别&#xff08;Level&#xff09;表示日志消息的优先级&#xff0c;从低到高分为以下几个级别&#xff1a; DEBUG: 详细的日志信息&#xff0c;通常用于调试。 INFO: 一般的信息性消息&#xff0c;用于说明程序运行情况。 WARNING: 警告消息&#xff0…...

FonePaw Data Recovery for Mac:轻松恢复丢失数据

FonePaw Data Recovery for Mac是一款功能强大的数据恢复软件&#xff0c;专为Mac用户设计&#xff0c;帮助用户轻松恢复因各种原因丢失的数据。该软件支持从硬盘驱动器、存储卡、闪存驱动器等存储介质中恢复丢失或删除的文件&#xff0c;包括照片、视频、文档、电子邮件、音频…...

C语言易错提醒选择题精选

Ⅰ 易错题 1.设有double p;&#xff0c;为变量p声明一个引用名称rp,则定义语句为 double& rpp; 2.已知‘A’一‘Z’的ASCII码为65—90&#xff0c;当执行“char ch14*52&#xff1b;cout<<ch<<endl;”语句序列后得到的输出结H &#xff0c;72对应ASCII码中…...

Android11系统去掉截屏功能

1. 去掉Settings里截屏菜单条目&#xff0c;packages/apps/Settings&#xff1a; diff --git a/res/xml/top_level_settings.xml b/res/xml/top_level_settings.xml old mode 100644 new mode 100755 index a5e4d06..a9420bb --- a/res/xml/top_level_settings.xmlb/res/xml/t…...

测试驱动来学习 Promise

基础功能 测试案例&#xff1a;以同步的方式调用。 /*** v1: 基础功能*/ const p1 new MyPromise((resolve, reject) > {resolve(success)reject(error) })p1.then((value) > {console.log(v1: , value) }) 实现功能&#xff1a;在 status 和 value 的位置暂存值&…...

Vue3实战笔记(20)—封装头部导航组件

文章目录 前言一、封装头部导航栏二、使用步骤总结 前言 Vue 3 封装头部导航栏有助于提高代码复用性、统一风格、降低维护成本、提高可配置性和模块化程度&#xff0c;同时还可以实现动态渲染等功能&#xff0c;有利于项目开发和维护。 一、封装头部导航栏 封装头部导航栏&am…...

Yolov8目标检测——在Android上部署Yolov8 tflite模型

1. 简介 YOLOv8 是一种用于目标检测的深度学习模型&#xff0c;它是 YOLO&#xff08;You Only Look Once&#xff09;系列的最新版本之一。YOLO 系列因其高效和准确性而在计算机视觉领域非常受欢迎&#xff0c;特别是在需要实时目标检测的应用中&#xff0c;如视频监控、自动…...

(delphi11最新学习资料) Object Pascal 学习笔记---第12章操作类(类方法和类数据)

第12章 操作类 ​ 在过去的几章中&#xff0c;你已经了解了 Object Pascal 语言面向对象的基础&#xff1a;类、对象、方法、构造函数、继承、后期绑定、接口等等。现在&#xff0c;我们需要进一步了解与类管理相关的一些更高级、更具体的语言特性。从类引用到类助手(class he…...

面向 C# 开发人员的电子邮件转换控件 - EML 到 PNG

本文将使 C# 开发人员能够以编程方式将EML或MSG转换为其他流行的文件格式。Aspose.Email 提供了类和方法以及在线 电子邮件转换器工具&#xff0c;可将 EML无缝转换为PNG 。如果不安装第三方软件&#xff0c;则无法打开 EML/MSG 文件。因此&#xff0c;将 EML/MSG 转换为 PNG 和…...

Vue3:数据交互axios

回调函数 > 回调函数: 一些特殊的函数,表示未来才会执行的一些功能,后续代码不会等待该函数执行完毕就开始执行了 1. Promise 1.1 简介 > 前端中的异步编程技术&#xff0c;类似Java中的多线程线程结果回调&#xff01; * Promise 是异步编程的一种解决方案&#xff0c…...

芯片的性能指什么

【省带宽、压成本专题】降低30%视频码率&#xff0c;深挖“窄带高清”的实现原理 - 知乎 芯片&#xff08;或微处理器、集成电路&#xff09;的性能主要指其完成特定任务的能力和效率。性能可以通过多种参数来衡量&#xff0c;这些参数反映了芯片设计的不同方面&#xff0c;包…...

Java通过百度地图API获取定位-普通IP定位

项目中有一个登录邮箱提醒的功能&#xff0c;需要根据IP地址获取定位信息&#xff0c;从而更好地提示用户账号登录的所在地。为此&#xff0c;花费了一些时间来实现这个功能。 在CSDN搜索了一下&#xff0c;发现关于获取定位的文章说明都不够详细&#xff0c;于是决定自己创作一…...

5月13号作业

使用消息队列实现的2个终端之间的互相聊天 并使用信号控制消息队列的读取方式&#xff1a; 当键盘按ctrlc的时候&#xff0c;切换消息读取方式&#xff0c;一般情况为读取指定编号的消息&#xff0c;按ctrlc之后&#xff0c;指定的编号不读取&#xff0c;读取其他所有编号的消息…...

【计算机网络】Socket网络编程

&#x1f4bb;文章目录 &#x1f4c4;前言Socket编程基础概念工作原理 Socket API介绍socket函数绑定、监听函数accept、connect接受/发送函数 Socket API的应用Socket类与其派生类的设计服务器与客户端的设计使用 &#x1f4d3;总结 &#x1f4c4;前言 现今我们的日常生活当中…...

Ansible自动运维工具之playbook

目录 一.inventory主机清单 1.定义 2.变量 &#xff08;1&#xff09;主机变量 &#xff08;2&#xff09;组变量 &#xff08;3&#xff09;组嵌套 二.playbook基本内容 1.组成 &#xff08;1&#xff09;Tasks: 任务&#xff0c;即调用模块完成的某操作 &#xff0…...

【启明智显技术分享】SSD201/SSD202D核心板UI界面开发全攻略:LVGL使用指南

提示&#xff1a;作为Espressif&#xff08;乐鑫科技&#xff09;大中华区合作伙伴及sigmastar&#xff08;厦门星宸&#xff09;VAD合作伙伴&#xff0c;我们不仅用心整理了你在开发过程中可能会遇到的问题以及快速上手的简明教程供开发小伙伴参考。同时也用心整理了乐鑫及星宸…...

数据可视化(九):Pandas北京租房数据分析——房源特征绘图、箱线图、动态可视化等高级操作

Tips&#xff1a;"分享是快乐的源泉&#x1f4a7;&#xff0c;在我的博客里&#xff0c;不仅有知识的海洋&#x1f30a;&#xff0c;还有满满的正能量加持&#x1f4aa;&#xff0c;快来和我一起分享这份快乐吧&#x1f60a;&#xff01; 喜欢我的博客的话&#xff0c;记得…...

ADOP带你了解:跳线与交叉电缆有何不同?

如果您想将设备连接到互联网&#xff0c;您可能想知道要使用的正确电缆。跳线和交叉电缆都是类型的以太网电缆&#xff0c;可帮助连接计算机、调制解调器、路由器和交换机等设备。那么&#xff0c;跳线和交叉电缆有什么区别呢&#xff1f;让我们讨论这两种类型的电缆&#xff0…...

Django 和 Spring Boot

标题 Django (Python)Django提供的组件Django 的处理逻辑 Spring Boot (Java)Spring Boot 的特点Spring Boot 的处理逻辑 MVC设计模式模型&#xff08;Model&#xff09;视图&#xff08;View&#xff09;控制器&#xff08;Controller&#xff09;逻辑处理过程 Django 和 Spri…...

【第二十一章 SDIO接口(SDIO)】

第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

Python实现prophet 理论及参数优化

文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候&#xff0c;写过一篇简单实现&#xff0c;后期随着对该模型的深入研究&#xff0c;本次记录涉及到prophet 的公式以及参数调优&#xff0c;从公式可以更直观…...

苍穹外卖--缓存菜品

1.问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得&#xff0c;如果用户端访问量比较大&#xff0c;数据库访问压力随之增大 2.实现思路 通过Redis来缓存菜品数据&#xff0c;减少数据库查询操作。 缓存逻辑分析&#xff1a; ①每个分类下的菜品保持一份缓存数据…...

反射获取方法和属性

Java反射获取方法 在Java中&#xff0c;反射&#xff08;Reflection&#xff09;是一种强大的机制&#xff0c;允许程序在运行时访问和操作类的内部属性和方法。通过反射&#xff0c;可以动态地创建对象、调用方法、改变属性值&#xff0c;这在很多Java框架中如Spring和Hiberna…...

mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包

文章目录 现象&#xff1a;mysql已经安装&#xff0c;但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时&#xff0c;可能是因为以下几个原因&#xff1a;1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...

C++八股 —— 单例模式

文章目录 1. 基本概念2. 设计要点3. 实现方式4. 详解懒汉模式 1. 基本概念 线程安全&#xff08;Thread Safety&#xff09; 线程安全是指在多线程环境下&#xff0c;某个函数、类或代码片段能够被多个线程同时调用时&#xff0c;仍能保证数据的一致性和逻辑的正确性&#xf…...

JAVA后端开发——多租户

数据隔离是多租户系统中的核心概念&#xff0c;确保一个租户&#xff08;在这个系统中可能是一个公司或一个独立的客户&#xff09;的数据对其他租户是不可见的。在 RuoYi 框架&#xff08;您当前项目所使用的基础框架&#xff09;中&#xff0c;这通常是通过在数据表中增加一个…...

智能AI电话机器人系统的识别能力现状与发展水平

一、引言 随着人工智能技术的飞速发展&#xff0c;AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术&#xff0c;在客户服务、营销推广、信息查询等领域发挥着越来越重要…...

使用Spring AI和MCP协议构建图片搜索服务

目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式&#xff08;本地调用&#xff09; SSE模式&#xff08;远程调用&#xff09; 4. 注册工具提…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)

RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发&#xff0c;后来由Pivotal Software Inc.&#xff08;现为VMware子公司&#xff09;接管。RabbitMQ 是一个开源的消息代理和队列服务器&#xff0c;用 Erlang 语言编写。广泛应用于各种分布…...