博客
关于我
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实现LZW编码(附完整源码)
查看>>
Objective-C实现MAC桌面暗水印(附完整源码)
查看>>
Objective-C实现mandelbrot曼德勃罗特集算法(附完整源码)
查看>>
Objective-C实现markov chain马尔可夫链算法(附完整源码)
查看>>
Objective-C实现MATLAB中Filter函数功能(附完整源码)
查看>>
Objective-C实现matrix chainorder矩阵链顺序算法(附完整源码)
查看>>
Objective-C实现matrix exponentiation矩阵求幂算法(附完整源码)
查看>>
Objective-C实现MatrixMultiplication矩阵乘法算法 (附完整源码)
查看>>
Objective-C实现max non adjacent sum最大非相邻和算法(附完整源码)
查看>>
Objective-C实现max subarray sum最大子数组和算法(附完整源码)
查看>>
Objective-C实现max sum sliding window最大和滑动窗口算法(附完整源码)
查看>>
Objective-C实现MaxHeap最大堆算法(附完整源码)
查看>>
Objective-C实现MaximumSubarray最大子阵列(Brute Force蛮力解决方案)算法(附完整源码)
查看>>
Objective-C实现MaximumSubarray最大子阵列(动态规划解决方案)算法(附完整源码)
查看>>
Objective-C实现maxpooling计算(附完整源码)
查看>>
Objective-C实现max_difference_pair最大差异对算法(附完整源码)
查看>>
Objective-C实现max_heap最大堆算法(附完整源码)
查看>>
Objective-C实现MD5 (附完整源码)
查看>>
Objective-C实现md5算法(附完整源码)
查看>>
Objective-C实现MeanSquareError均方误差算法 (附完整源码)
查看>>