博客
关于我
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/

你可能感兴趣的文章
Objective-C内存管理教程和原理剖析(三)
查看>>
Objective-C实现 Greedy Best First Search最佳优先搜索算法(附完整源码)
查看>>
Objective-C实现 jugglerSequence杂耍者序列算法 (附完整源码)
查看>>
Objective-C实现 lattice path格子路径算法(附完整源码)
查看>>
Objective-C实现1000 位斐波那契数算法(附完整源码)
查看>>
Objective-C实现2 个数字之间的算术几何平均值算法(附完整源码)
查看>>
Objective-C实现2d 表面渲染 3d 点算法(附完整源码)
查看>>
Objective-C实现2D变换算法(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现9x9乘法表算法(附完整源码)
查看>>
Objective-C实现9×9二维数组数独算法(附完整源码)
查看>>
Objective-C实现A*(A-Star)算法(附完整源码)
查看>>
Objective-C实现A-Star算法(附完整源码)
查看>>
Objective-C实现abbreviation缩写算法(附完整源码)
查看>>
Objective-C实现ABC人工蜂群算法(附完整源码)
查看>>
Objective-C实现activity selection活动选择问题算法(附完整源码)
查看>>
Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
查看>>
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>