百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Python 面试问题:自定义函数

itomcoil 2025-01-06 13:21 10 浏览

Python 中自定义函数可以使用关键字 def,如以下代码所示:

def function_name ( ):
    to do statements

让我们定义一个简单的函数:

def hello() :
    print("Hello World!")

hello() 函数是一个非常简单的函数,在调用时仅显示 Hello World!。

还可以将参数传递给函数。如果希望函数 hello() 打印个性化消息,需要将参数传递给函数。

def hello(name) :
    print("Hello", name)

函数调用

def hello(name) :
    print("Hello", name)
name = input("请输入名字:")
hello(name)
# 输出:
请输入名字:jack
Hello jack

问题 1.Python 中有哪些不同类型的函数

Python 中有两种类型的函数:

  • 内置函数:Python 中的库函数
  • 用户定义的函数:由开发人员定义

问题 2.为什么需要自定义函数

在一个程序中,很多时候可能会一次又一次地调用某组代码。与其在需要的地方编写相同的代码段,不如定义一个函数并将代码放入其中。只要有需要,就可以调用此函数。这样可以节省时间和精力,有助于组织编码工作,代码测试也变得容易。

问题 3.什么是函数头

以 def 开头并以冒号 (:) 结尾的函数定义的第一行称为函数头。

问题 4.函数何时执行

当对函数进行调用时,函数将执行。可以直接从 Python 提示符或其他函数调用。

问题 5.什么是参数,参数和变量有什么区别

参数是在函数定义中定义的变量,而变量是传递给函数的实际值。变量中携带的数据将传递给参数。

def function_name(param):

在前面的语句中,param 是一个参数。

问题 6.什么是默认参数

默认参数也称为可选参数。在定义函数时,如果参数提供了默认值,则称为默认参数。如果在调用函数时,用户未为此参数提供任何值,则该函数将使用它的默认值。如下代码 age 是可选参数。

def hello(name, age=10) :
    print(f"my name is {name},I'm {age} years old.")
name = input("请输入名字:")
hello(name)
'''输出:
请输入名字:jack
my name is jack,I'm 10 years old.
'''

def hello(name, age=10) :
    print(f"my name is {name},I'm {age} years old.")
name = input("请输入名字:")
hello(name,20)
'''输出:
请输入名字:jack
my name is jack,I'm 20 years old.
'''

问题 7.Python 中的函数参数有哪些类型?

Python 中有三种类型的函数参数:

  1. 默认参数: 如果用户没有提供任何值,则假定为默认值。
  2. 关键字参数: 对于具有多个默认参数值的函数来说,必须按顺序指定其参数值。在调用函数时,使用参数的关键字来指定为哪个参数赋值,而不管它们的位置如何。
def hello(name, age) :
    print(f"my name is {name},I'm {age} years old.")
hello(age=10,name='jack')
  1. 可变长度参数: 如果不确定函数参数的个数,可以使用可变长度参数。在函数定义中,使用一个星号标注可变长参数,此时,传入的多个参数将被封装为一个元组传入函数内。

对于同时带有参数名和实际传入对象的关键字参数,也可一次性传入多个,即可变长关键字参数。与可变长参数不同,可变长关键字参数需要用两个星号来进行说明,同时实际传入过程是 python 会将其转化为字典进行传入

def mysum(*num):               
    r = 0
    for i in num:             
        r += i
    return(r)
print(mysum(1,2)) 
print(mysum(1,2,3))

def myFun(**kwargs):
    for i in kwargs:
        print(i,'-',kwargs[i])

myFun(a=10, b=20, c=30, d=40)

问题 8.将不可变对象和可变对象作为参数传递给函数有什么区别

如果将字符串、元组等不可变参数传递给函数,则会传递对象引用,但无法更改这些参数的值。它的作用类似于按值传递调用。可变对象也通过对象引用传递,但其值可以更改。

问题 9.编写一个函数,使用 for 循环查找数字的阶乘

def factorial(number):
    j = 1
    if number==0|number==1:
        print(j)
    else:
        for i in range (1, number+1):
            print (j," * ",i," = ", j * i)
            j = j*i
factorial(5)

问题 10.自定义函数,使用 for 循环输出斐波那契数列

def fibonacci(num):
    i = 0
    j = 0
    k = 0
    for i in range(num):
        if i==0:
            print(j)
        elif i==1:
            j = 1
            print(j)
        else:
            temp = j
            j = j+k
            k = temp
            print(j)
fibonacci(10)

问题 11.使用 while 循环改写以下代码

def func(i, j):
    if i == 0:
        return j
    else:
        return func(i-1, j+1)
print(func(6,7))
def func(i,j):
    while i > 0:
        i =i- 1
        j = j + 1
    return j
print(func(6, 7))

问题 12.编写代码查找两个给定数字的最大公约数

def hcf(x,y):
    small_num = 0
    if x>y:
        small_num = y
    else:
        small_num = x
    for i in range (1, small_num+1):
        if (x % i ==0) and (y % i ==0):
            hcf = i
    return hcf
print (hcf(6,24))

问题 13.以下代码的输出是什么

total = 0
def add(a,b):
    global total
    total = a+b
    print("inside total = ", total)

add(6,7)
print("outside total = ", total)

输出如下:

inside total = 13

outside total = 13

问题 14.以下代码的输出是什么

total = 0
def add(a,b):
    total = a+b
    print("inside total = ", total)

add(6,7)
print("outside total = ", total)

输出如下:

inside total = 13

outside total = 0

问题 15.编写代码以使用欧几里得算法查找 HCF

欧几里得算法又称辗转相除法,是指用于计算两个非负整数a,b的最大公约数。两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。前面使用递归函数计算最大公约数也使用了使用欧几里得算法。

def GCD(a, b): 
   while b != 0: 
       a, b = b, a % b 
   return a 
  
a=28
b=72
print(f"{a}和{b}的最大公约数是:{GCD(a,b)} ")

问题 16.编写代码以在字符串中查找所有可能的回文分区

通过使用 for 循环将字符串切片得到成所有可能的子字符串。然后检查每个子字符串,看看它是否是回文。

子字符串将转换为单个字符的列表。以相反的顺序,将列表中的字符连接为字符串。如果生成的字符串与原始字符串匹配,则它是回文。

def create_substrings(x):
    substrings = [ ]
    for i in range(len(x)):
        for j in range(1, len(x)+1):
            if x[i:j]!= '':
                substrings.append(x[i:j])              
    for i in substrings:
        check_palin(i)

def check_palin(x):
    palin_str = ''
    palin_list = list(x)
    y = len(x)-1
    while y>=0:
        palin_str = palin_str + palin_list[y]
        y = y-1
    if palin_str == x:
        print(x,"是回文!")
x = "mlayalam"
create_substrings(x)

输出

m 是回文!
l 是回文!
layal 是回文!
a 是回文!
aya 是回文!
y 是回文!
a 是回文!
ala 是回文!
l 是回文!
a 是回文!
m 是回文!

问题 17.什么是匿名函数

Python 中的 Lambda 可用于创建没有名称的函数。此类函数也称为匿名函数。Lambda 函数体中只有一行,不需要 return 语句。

total = lambda a, b: a + b
print(total(10,50))

问题 18.return 语句有什么用

return 语句退出函数并将值交还给函数的调用方,即返回函数执行结果。

def func(a,b):
    return a+b
total = func(1, 2)
print(total)

问题 19.以下代码的输出什么

def happyBirthday():
    print("Happy Birthday")
a = happyBirthday()
print(a)

输出:

Happy Birthday None

问题 20.以下代码的输出什么

m = 1
n = 2
def update_variables():
    global m
    m = 11
    n = 22 
update_variables()
print(m) 
print(n) 

11

2

?

文章创作不易,如果您喜欢这篇文章,请关注、点赞并分享给朋友。如有意见和建议,请在评论中反馈!

?

相关推荐

tesseract-ocr 实现图片识别功能

最近因为项目需要,接触了一下关于图像识别的相关内容,例如Tesseract。具体如何安装、设置在此不再赘述。根据项目要求,我们需要从省平台获取实时雨水情况数据,原以为获取这样的公开数据比较简单,上去一...

跨平台Windows和Linux(银河麒麟)操作系统OCR识别应用

1运行效果在银河麒麟桌面操作系统V10(SP1)上运行OCR识别效果如下图:2在Linux上安装TesseractOCR引擎2.1下载tesseract-ocr和leptonicahttps:...

JAVA程序员自救之路——SpringAI文档解析tika

ApacheTika起源于2007年3月,最初是ApacheLucene项目的子项目,于2010年5月成为Apache组织的顶级项目。它利用现有的解析类库,能够侦测和提取多种不同格式文档中的元数据...

Python印刷体文字识别教程

在Python中实现印刷体文字识别(OCR),通常使用TesseractOCR引擎结合Python库。以下是详细步骤和示例:1.安装依赖库bashpipinstallpytesseractp...

图片转文字--四种OCR工具的安装和使用

本文仅测试简单的安装和使用,下一步应该是测试不同数据集下的检测准确率和检测效率,敬请期待。作者的系统环境是:笔记本:ThindPadP520OS:win11显卡:QuadroP520一、EasyO...

mac 安装tesseract、pytesseract以及简单使用

一.tesseract-OCR的介绍1.tesseract-OCR是一个开源的OCR引擎,能识别100多种语言,专门用于对图片文字进行识别,并获取文本。但是它的缺点是对手写的识别能力比较差。2.用te...

【Python深度学习系列】Win10下CUDA+cuDNN+Tensorflow安装与配置

这是我的第292篇原创文章。一、前置知识安装GPU版本的pytorch和tensorflow之前需要理清楚这几个关系:显卡(电脑进行数模信号转换的设备,有的电脑可能是双显卡,一个是inter的集成显卡...

手把手教你本地部署AI绘图Stable Diffusion!成功率100%!

导语:无需每月付费订阅,无需高性能服务器!只需一台普通电脑,即可免费部署爆火的AI绘图工具StableDiffusion。本文提供“极速安装包”和“手动配置”双方案,从环境搭建到模型调试,手把手教你...

本地AI Agent Hello World(Python版): Ollama + LangChain 快速上手指南

概要本文将用最简洁的Python示例(后续还会推出Java版本),带你逐步完成本地大模型Agent的“HelloWorld”:1、介绍核心工具组件:Ollama、LangChain和...

python解释器管理工具pyenv使用说明

简介pyenv可以对python解释器进行管理,可以安装不同版本的python,管理,切换不同版本很方便,配置安装上比anaconda方便。pyenv主要用来对Python解释器进行管理,可以...

Deepseek实战:企业别只会用Ollama,也可以用SGLang

SGLang:企业级的“性能之王”优点吞吐量碾压级优势通过零开销批处理调度器、缓存感知负载均衡器等核心技术,SGLang的吞吐量提升显著。例如,在处理共享前缀的批量请求时,其吞吐量可达158,59...

用LLaMA-Factory对Deepseek大模型进行微调-安装篇

前面的文章已经把知识库搭建好了,还通过代码的形式做完了RAG的实验。接下来呢,咱们要通过实际操作来完成Deepseek的另一种优化办法——微调。一、环境因为我这台电脑性能不太好,所以就在Au...

碎片时间学Python-03包管理器

一、pip(Python官方包管理器)1.基础命令操作命令安装包pipinstallpackage安装特定版本pipinstallnumpy==1.24.0升级包pipinstall-...

ubuntu22/24中利用国内源部署大模型(如何快速安装必备软件)

本地AI部署的基础环境,一般会用到docker,dockercompose,python环境,如果直接从官网下载,速度比较慢。特意记录一下ubuntu使用国内源快速来搭建基础平台。一,docke...

还不会deepseek部署到本地?这篇教程手把手教会你

一、为什么要把DeepSeek部署到本地?新手必看的前置知识近期很多读者在后台询问AI工具本地部署的问题,今天以国产优质模型DeepSeek为例,手把手教你实现本地化部署。本地部署有三大优势:数据隐私...