博客
关于我
python实现switch
阅读量:162 次
发布时间:2019-02-28

本文共 736 字,大约阅读时间需要 2 分钟。

我们来看一个经典的例子:计算器实现。假设我们要实现一个简单的计算器,那么是否需要判断运算符是加减乘除?大家可能会说,用if语句判断不就可以了?但这种方法会导致代码冗余,占用大量空间。我们以计算器为例,来看看如何实现更高效的解决方案。

传统的方法是使用if语句来判断运算符类型。比如:

def jia(x, y):    return x + ydef jian(x, y):    return x - ydef cheng(x, y):    return x * ydef chu(x, y):    return x / yopr = {    "+": jia,    "-": jian,    "*": cheng,    "/": chu}print(opr["+"](2, 3))

这种方法虽然简单,但代码重复率较高,难以维护和扩展。

相比之下,我们可以通过字典映射的方式实现运算符的多态性。这种方法既简洁又高效,代码量大幅减少,易于扩展。

def jia(x, y):    return x + ydef jian(x, y):    return x - ydef cheng(x, y):    return x * ydef chu(x, y):    return x / yopr = {    "+": jia,    "-": jian,    "*": cheng,    "/": chu}print(opr["+"](2, 3))

这种方法的核心思想是将运算符与相应的函数绑定,通过字典查找快速执行相应的操作。这种方式代码简洁,功能模块化,且易于维护和扩展。如果需要增加新的运算符,只需在字典中添加对应的函数即可,无需修改现有代码。

转载地址:http://dlzj.baihongyu.com/

你可能感兴趣的文章
OpenCV中的监督学习
查看>>
opencv中读写视频
查看>>
opencv之cv2.findContours和drawContours(python)
查看>>
opencv之namedWindow,imshow出现两个窗口
查看>>
opencv之模糊处理
查看>>
Opencv介绍及opencv3.0在 vs2010上的配置
查看>>
OpenCV使用霍夫变换检测图像中的形状
查看>>
opencv保存图片路径包含中文乱码解决方案
查看>>
OpenCV保证输入图像为三通道
查看>>
opencv图像分割2-GMM
查看>>
opencv图像分割3-分水岭方法
查看>>
opencv图像切割1-KMeans方法
查看>>
OpenCV图像处理篇之阈值操作函数
查看>>
OpenCV图像的深浅拷贝
查看>>
OpenCV学习(13) 细化算法(1)(转)
查看>>
OpenCV学习笔记(27)KAZE 算法原理与源码分析(一)非线性扩散滤波
查看>>
OpenCV学堂 | OpenCV案例 | 基于轮廓分析对象提取
查看>>
OpenCV官方文档 理解k - means聚类
查看>>
OpenCV探索
查看>>
openCV目标识别 目标跟踪 YOLO5深度学习 Python 计算机视觉 计算机毕业设计 源码下载
查看>>