Python常见面试题的详解8
1. 变量作用域和查找规则(LEGB)
- 作用域层级:
-
Local:函数内部作用域
-
Enclosing:闭包函数外层作用域
-
Global:模块全局作用域
-
Built-in:内置命名空间
- 查找顺序:L → E → G → B
- 关键特性:
global声明修改全局变量
nonlocal修改闭包外层变量
函数参数属于局部作用域
python
x = 'global'
def outer():x = 'outer'def inner():nonlocal x # 修改闭包变量x = 'inner'inner()print(x) # 输出 'inner'
- 要点:
Python 中有四种作用域:局部作用域(Local,L)、闭包函数外的函数中作用域(Enclosing,E)、全局作用域(Global,G)、内置作用域(Built - in,B)。变量查找顺序遵循 LEGB 规则,即先在局部作用域查找,若未找到则到闭包函数外的函数中作用域查找,接着是全局作用域,最后是内置作用域。在嵌套函数中,内层函数可以访问外层函数的变量,但默认情况下不能修改。如果需要修改,可以使用 nonlocal 关键字。在模块中定义的变量属于全局作用域,但在函数内部如果使用 global 关键字,可以修改全局变量的值。
- 示例:
python
def outer():x = 10def inner():nonlocal xx = 20inner()print(x) # 输出 20outer()
2. 用三种方式将字符串 "789" 转换成 789 ,不使用内置 api,例如 int()
python
# 方法1:ASCII码计算
def str_to_int(s):num = 0for c in s:num = num*10 + (ord(c) - ord('0'))return num# 方法2:逐位乘累加
def str_to_int(s):return sum((ord(c)-48)*10**i for i,c in enumerate(reversed(s)))# 方法3:递归实现
def str_to_int(s, acc=0):return acc if not s else str_to_int(s[1:], acc*10 + (ord(s[0])-48))
- 要点:
可以使用 ASCII 码和乘法,加法运算,通过循环和位运算,使用递归这些方法可以实现对字符串和整数之间转换。在一些对性能要求较高且不允许使用内置函数的场景下,这些手动实现的转换方法会更有优势。
- 示例:
python
# 方法一:利用 ASCII 码和乘法、加法运算
def str_to_int_1(s):result = 0for char in s:result = result * 10 + (ord(char) - ord('0'))return result# 方法二:通过循环和位运算
def str_to_int_2(s):num = 0for i in range(len(s)):digit = ord(s[i]) - ord('0')num = (num << 3) + (num << 1) + digitreturn num# 方法三:使用递归
def str_to_int_3(s):if len(s) == 0:return 0return str_to_int_3(s[:-1]) * 10 + (ord(s[-1]) - ord('0'))print(str_to_int_1("789"))
print(str_to_int_2("789"))
print(str_to_int_3("789"))
3. 给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。
- 要点:
- 暴力枚举法,通过两层循环遍历数组,找到满足条件的两个数。
- 使用哈希表,遍历数组时,记录每个元素及其索引,同时检查目标值与当前元素的差值是否已在哈希表中。
- 在处理大规模数组时,哈希表的优势会更加明显。该问题还可以扩展到找出数组中三个数、四个数之和等于目标值的情况。
- 示例:
python
# 方法一:暴力枚举法
def twoSum_1(nums, target):for i in range(len(nums)):for j in range(i + 1, len(nums)):if nums[i] + nums[j] == target:return [i, j]# 方法二:使用哈希表
def twoSum_2(nums, target):num_dict = {}for i, num in enumerate(nums):complement = target - numif complement in num_dict:return [num_dict[complement], i]num_dict[num] = inums = [1, 2, 3, 4]
target = 3
print(twoSum_1(nums, target))
print(twoSum_2(nums, target))
4. 用三种方式统计一个文本中单词频次最高的 10 个单词
- 要点:
- 使用字典手动统计单词频次,然后对字典按值排序。
- 使用
collections.Counter类,可以方便地统计元素的频次。 - 结合
defaultdict和heapq模块,利用堆排序找出前 10 个高频单词。 -
在处理大规模文本时,
collections.Counter是比较高效的选择,因为它的实现经过了优化。而使用heapq模块可以在不排序整个单词频次字典的情况下找出前 10 个高频单词,在内存使用上可能更有优势。
- 示例:
python
import collections
import heapqtext = "apple banana apple cherry banana apple"# 方法一:使用字典手动统计
word_count = {}
for word in text.split():if word in word_count:word_count[word] += 1else:word_count[word] = 1
sorted_words = sorted(word_count.items(), key=lambda item: item[1], reverse=True)[:10]
print(sorted_words)# 方法二:使用 collections.Counter
counter = collections.Counter(text.split())
print(counter.most_common(10))# 方法三:结合 defaultdict 和 heapq
from collections import defaultdict
word_freq = defaultdict(int)
for word in text.split():word_freq[word] += 1
heap = [(-freq, word) for word, freq in word_freq.items()]
heapq.heapify(heap)
top_10 = [heapq.heappop(heap) for _ in range(min(10, len(heap)))]
result = [(word, -freq) for freq, word in top_10]
print(result)
5. 请写出一个函数满足以下条件:该函数的输入是一个仅包含数字的 list,输出一个新的 list,其中每一个元素要满足以下条件:
- 该元素是奇数
- 该元素在原
list中是在奇数的位置(index是奇数)
- 要点:
使用列表推导式遍历原列表,筛选出满足条件的元素。可以定义一个函数应用于数据处理中,例如从一系列测量数据中筛选出特定位置的奇数测量值。对于不同的数据类型或更复杂的筛选条件,可以对该函数进行扩展。
- 示例:
python
def filter_list(lst):return [lst[i] for i in range(1, len(lst), 2) if lst[i] % 2 != 0]nums = [1, 2, 3, 4, 5, 6, 7, 8, 9]
print(filter_list(nums))
6. 使用单一的列表生成式来产生一个新的列表
- 要点:
列表生成式可以结合条件判断、循环等操作,以简洁的语法生成新列表。列表生成式不仅可以用于生成简单的数值列表,还可以用于处理嵌套列表、字符串列表等。在处理复杂的数据结构时,合理使用列表生成式可以使代码更加简洁易读。
- 示例:
生成一个包含 1 到 10 的平方的列表:
python
squares = [i ** 2 for i in range(1, 11)]
print(squares)
7. 用一行代码生成 [1,4,9,16,25,36,49,64,81,100]
python
squares = [x**2 for x in range(1,11)] # [1,4,9,...,100]
- 要点:
使用列表生成式 [x ** 2 for x in range(1, 11)] 可以在一行代码中完成列表的生成。可以通过修改 range 的参数和表达式,生成不同规律的列表。例如,生成 2 到 20 的偶数的平方列表:[x ** 2 for x in range(2, 21, 2)]。
8. 输入某年某月某日,判断这一天是这一年的第几天
- 要点:
- 先判断该年是否为闰年,闰年 2 月有 29 天,平年 2 月有 28 天。
- 然后累加每个月的天数,直到输入的月份,再加上输入的日期。
- 可以将该功能封装成一个函数,方便在不同的程序中调用。同时,可以添加输入验证,确保输入的日期是合法的。
- 示例:
python
def day_of_year(year, month, day):days_in_month = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]if (year % 4 == 0 and year % 100 != 0) or (year % 400 == 0):days_in_month[1] = 29total_days = sum(days_in_month[:month - 1]) + dayreturn total_daysyear = 2024
month = 3
day = 15
print(day_of_year(year, month, day))
9. 两个有序列表l1,l2,对这两个列表进行合并不可使用 extend
- 要点:
使用双指针法,分别遍历两个列表,比较指针所指元素的大小,将较小的元素添加到新列表中,直到其中一个列表遍历完,然后将另一个列表剩余的元素依次添加到新列表中。在处理多个有序列表的合并时,可以使用归并排序的方法,将多个列表两两合并。
- 示例:
python
def merge_lists(l1, l2):merged = []i, j = 0, 0while i < len(l1) and j < len(l2):if l1[i] < l2[j]:merged.append(l1[i])i += 1else:merged.append(l2[j])j += 1while i < len(l1):merged.append(l1[i])i += 1while j < len(l2):merged.append(l2[j])j += 1return mergedl1 = [1, 3, 5]
l2 = [2, 4, 6]
print(merge_lists(l1, l2))
10. 给定一个任意长度数组,实现一个函数让所有奇数都在偶数前面,而且奇数升序排列,偶数降序排序,如字符串 '123456789',变成 '135798642'
- 要点:
- 先将数组中的奇数和偶数分别提取出来。
- 对奇数列表进行升序排序,对偶数列表进行降序排序。
- 最后将排序后的奇数列表和偶数列表合并。
- 可以定义一个函数应用于数据排序和整理的场景中,对于不同的数据类型(如整数列表、字符串列表等),可以进行相应的修改。
- 示例:
python
def sort_array(arr):odd_nums = [int(i) for i in arr if int(i) % 2 != 0]even_nums = [int(i) for i in arr if int(i) % 2 == 0]odd_nums.sort()even_nums.sort(reverse=True)result = [str(i) for i in odd_nums + even_nums]return ''.join(result)arr = '123456789'
print(sort_array(arr))
相关文章:
Python常见面试题的详解8
1. 变量作用域和查找规则(LEGB) 作用域层级: Local:函数内部作用域 Enclosing:闭包函数外层作用域 Global:模块全局作用域 Built-in:内置命名空间 查找顺序:L → E → G → B关…...
【含文档+PPT+源码】基于微信小程序的校园志愿者管理系统的设计与实现
项目介绍 本课程演示的是一款 基于微信小程序的校园志愿者管理系统的设计与实现,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含:项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本…...
LED灯闪烁实验:实验介绍
文章目录 1 实验目标2 工具链2.1 硬件2.2 软件 3 实验流程 1 实验目标 本实验结合Matlab/Simulink工具链和STM工具链,实现STM32开发板上的LED灯闪烁功能。 2 工具链 2.1 硬件 STM32F103C8T6最小系统板 STM32F103C8T6最小系统板是基于STM32F103C8T6微控制器的开发…...
亲测Windows部署Ollama+WebUI可视化
一. Ollama下载 登录Ollama官网(Ollama)点击Download进行下载 如果下载很慢可用以下地址下载: https://github.com/ollama/ollama/releases/download/v0.5.7/OllamaSetup.exe 在DeepSeek官网上,你可以直接点击【model】 到达这个界面之后,…...
代码随想录-- 第一天图论 --- 岛屿的数量
99 统计岛屿的数量 c 99. 岛屿数量 #include <iostream> #include <vector> #include <queue>using namespace std;struct MGraph {int numVertices, numEdges;vector<vector<int>> Edge; };int dir[4][2] {{1, 0}, {0, 1}, {-1, 0}, {0, -1}…...
Docker 部署 Nacos (图文并茂超详细)
部署 Nacos ( Docker ) [Step 1] : 拉取 Nacos 镜像 docker pull nacos/nacos-server:v2.1.1[Step 2] : 创建目录 ➡️ 创建容器 ➡️ 拷贝文件 ➡️ 授权文件 ➡️ 删除容器 # 创建目录 mkdir -p /data/nacos/{conf,logs,data}# 创建容器 docker run -p 8848:8848 --name …...
petalinux高版本设置自动登录和开机自启动配置
petalinux-config -c rootfs 依次选择 Image Features -> serial-autologin-root 这是配置 进来就是root权限 创建并安装名为 myapp-init 的新建应用程序 petalinux-create -t apps --template install -n myapp-init --enable 编辑 project-spec/meta-user/recipes-…...
MySQL 的存储引擎简介
使用show engines可以查看安装的MySQL的引擎相关信息 MySQL 的引擎不止这么多,这只是安装的这个版本有的引擎。可以看到,只有 InnoDB 支持事务,其他的引擎都是不支持事务的。 说几个我了解的比较多的引擎: InnoDB InnoDB 是MyS…...
《Operating System Concepts》阅读笔记:p34-p40
《Operating System Concepts》学习第 7 天,p34-p40 总结,总计 7 页。 一、技术总结 1.virtualization(虚拟化) (1)定义 A technology for abstracting the hardware of a single computer into several different execution environments, thereby …...
嵌入式0xDEADBEEF
在嵌入式系统中,0xDEADBEEF 是一个常见的“魔数”(magic number),通常用于调试和内存管理。它的含义和用途如下: 1. 调试用途 未初始化内存的标记:在调试时,0xDEADBEEF 常用于标记未初始化或已…...
“深入浅出”系列之QT:(10)Qt接入Deepseek
项目配置: 在.pro文件中添加网络模块: QT core network API配置: 将apiUrl替换为实际的DeepSeek API端点 将apiKey替换为你的有效API密钥 根据API文档调整请求参数(模型名称、温度值等) 功能说明: 使…...
php文件包含
文章目录 基础概念php伪协议什么是协议协议的格式php中的协议file协议http协议ftp协议php://input协议php://filter协议php://data协议 php文件上传机制高级文件包含nginx文件日志包含临时文件包含session文件包含pear文件包含远程文件包含 基础概念 文件包含,相当…...
第四天面试题
文章目录 1.什么叫 Java 的内存泄露与内存溢出?**1. 内存泄露(Memory Leak)****内存泄露的常见原因:****如何避免内存泄露:** **2. 内存溢出(Out Of Memory, OOM)****内存溢出的常见原因&#x…...
网络技术变迁:从IPv4走向IPv6
目录 前言 旧时代产物:IPv4 什么是IPv4? IPv4的工作方式 IPv4的缺点 为什么要从IPv4过渡到IPv6? 走向IPv6:新一代互联网协议 IPv6的技术特性 我们需要过渡技术 双栈(Dual Stack) 隧道技术&#…...
突破反爬困境:从服务端渲染到客户端SPA,爬虫环境的演变与新挑战(一)
声明 本文所讨论的内容及技术均纯属学术交流与技术研究目的,旨在探讨和总结互联网数据流动、前后端技术架构及安全防御中的技术演进。文中提及的各类技术手段和策略均仅供技术人员在合法与合规的前提下进行研究、学习与防御测试之用。 作者不支持亦不鼓励任何未经授…...
ElasticSearch映射分词
目录 弃用Type why 映射 查询 mapping of index 创建 index with mapping 添加 field with mapping 数据迁移 1.新建 一个 index with correct mapping 2.数据迁移 reindex data into that index 分词 POST _analyze 自定义词库 ik分词器 circuit_breaking_excep…...
Vue.js 配置 Babel、Webpack 和 ESLint
Vue.js 配置 Babel、Webpack 和 ESLint 今天我们来聊聊如何配置 Babel、Webpack 和 ESLint,这三个工具在现代前端开发中扮演着重要角色。它们分别负责代码转译、模块打包和代码质量检测,合理配置它们能大大提高项目的开发效率和质量。下面我将详细介绍它…...
Es的text和keyword类型以及如何修改类型
昨天同事触发定时任务发现es相关服务报了一个序列化问题, 今天早上捕获异常将异常堆栈全部打出来看,才发现是聚合的字段不是keyword类型的问题。 到kibbna命令行执行也是一样的错误 使用 /_mapping查看索引的字段类型,才发现userUniqueid是te…...
1-18 GIT设置公钥
1-1 GIT如何设置公钥 1.0 注册账号 这个应该都是会的,就不做介绍了 2.0 设置公钥 PWD的作用是查看文件的路径 ssh-keygen -t ed25519 -C "Gitee SSH Key" 读取公钥文件: cat ~/.ssh/id_ed25519.pub 3.0 测试 查看绑定的用户名和邮箱࿱…...
什么是掉期(Swap)?——金融衍生品的关键工具(中英双语)
什么是掉期(Swap)?——金融衍生品的关键工具 引言 掉期(Swap) 是金融市场中最重要的衍生品之一,它允许两方交换未来的现金流,以优化融资成本、规避利率或汇率风险,甚至进行投机交易…...
Pytorch深度学习教程_3_初识pytorch
欢迎来到《PyTorch深度学习教程》系列的第三篇!在前面的两篇中,我们已经介绍了Python及numpy的基本使用。今天,我们将深入探索PyTorch的核心功能,帮助你更好地理解和使用这个强大的深度学习框架。 欢迎订阅专栏: 深度…...
基于Flask的艺恩影片票房分析系统的设计与实现
【Flask】基于Flask的艺恩影片票房分析系统的设计与实现(完整系统源码开发笔记详细部署教程)✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 该系统利用Python编程语言进行后端开发,结合Echarts进行数据的可视化展示&a…...
ollama-chat-ui-vue,一个可以用vue对接ollama的开源项目,可接入deepSeek
ollama-chat-ui-vue 使用vue3 vite elementUi 搭建的前端chat,通过ollama可与模型对话,目前支持独立思考,切换模型(联网查询后续支持) github地址:ollama-chat-ui-vue 制作不易github点点star,谢谢 前置工作 安装ollama,ollama官网地址 安装完olla…...
TCP开发
TCP客户端编程开发 任何的网络编程套接字开发的两种工作模式:TCP网络、UDP网络。 TCP和UDP的介绍 TCP:连接式网络通信,长连接通信或流式通信。TCP的通信一般稳定、可靠,但传输速度往往没有UDP快。其中有这样一个概念----心跳时…...
【核心算法篇十二】《深入解剖DeepSeek多任务学习:共享表示层的24个设计细节与实战密码 》
引言:为什么你的模型总在"精神分裂"? 想象你训练了一个AI实习生: 早上做文本分类时准确率90%下午做实体识别却把"苹果"都识别成水果公司晚上做情感分析突然开始输出乱码这就是典型的任务冲突灾难——模型像被不同任务"五马分尸"。DeepSeek通…...
Java 基于SpringBoot+Vue 的旅游网站信息化管理系统设计与实现
Java 基于SpringBootVue 的旅游网站信息化管理系统设计与实现 博主介绍:✌程序员徐师兄、8年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战*✌ 🍅文末获取源码联系ἴ…...
构建简单RAG代码实现
步骤1:文档准备与切割 假设我们有一个关于机器学习的PDF文档需要处理。 示例代码: Python 深色版本 from llama_index import SimpleDirectoryReader # 加载文档 documents SimpleDirectoryReader(./data).load_data() 说明: 使用Simple…...
kubeadm拉起的k8s集群证书过期的做法集群已奔溃也可以解决
kubeadm拉起的k8s集群证书过期的做法 这个是很久之前遇到的了,今天有空(心血来潮)就都回忆回忆写在这里为爱发光,部分内容来自arch先生(死党)的帮助。有时候有很多部门提了建k8s的需求,有些是临…...
Ubuntu:20.04更新cmake到更高版本
从输出信息可以看出,您当前的系统中已经安装了 cmake,但版本是 3.16.3,而您的项目需要 CMake 3.18 或更高版本。默认情况下,Ubuntu 20.04 的官方软件仓库中提供的 CMake 版本较低(如 3.16.3),因…...
php 系统命令执行及绕过
文章目录 php的基础概念php的基础语法1. PHP 基本语法结构2. PHP 变量3.输出数据4.数组5.超全局变量6.文件操作 php的命令执行可以执行命令的函数命令执行绕过利用代码中命令(如ls)执行命令替换过滤过滤特定字符串神技:利用base64编码解码的绕…...
