zoukankan      html  css  js  c++  java
  • 代码实现1-100奇数求和,至少3种方式。

    #代码实现1-100奇数求和,至少3种方式。
    ##方法1:循环
    #res=0
    #for i in range(1,100):
        #if i%2==1:
            #res=res+i
    #print(res)
    
    #2.
    #res=0
    #for i in range(1,100,2):#rang(1,100,2)代表从1到100取值,隔2取一次,1,3,5,7...99
        #res=res+i
    #print(res)
    
    ##方法2 sum函数.列表解析式,数组切片
    #res=sum([i for i in range(1,100) if i%2==1])
    #print(res)
    
    #res=sum([i for i in range(1,100,2)])
    #print(res)
    
    #res=sum(list(range(1,100))[::2])
    #print(res)
    
    '''
    list[start:end:step]
    
        start:起始位置
    
        end:结束位置
    
        step:步长
    
    >>> range(100)[20:30:2]
    [20, 22, 24, 26, 28]
    '''
    
    ##方法3 函数法
    #def func(x,y):
        #return x+y
    
    #res=0
    #for i in range(1,100,2):
        #res=func(res,i)
    #print(res)
    
    ##方法4: lambda函数+reduce
    from functools import reduce
    res=reduce(lambda x,y: x+y,range(1,100,2))
    print(res)
    '''
    reduce()函数也是Python内置的一个高阶函数。
    
    reduce()函数接收的参数和 map()类似,一个函数 f,一个list,但行为和 map()不同,reduce()传入的函数 f 必须接收两个参数,reduce()对list的每个元素反复调用函数f,并返回最终结果值。
    
    例如,编写一个f函数,接收x和y,返回x和y的和:
    
        1 def f(x, y):
        2 return x + y
        
    调用 reduce(f, [1, 3, 5, 7, 9])时,reduce函数将做如下计算:
    
        1 先计算头两个元素:f(1, 3),结果为4;
        2 再把结果和第3个元素计算:f(4, 5),结果为9;
        3 再把结果和第4个元素计算:f(9, 7),结果为16;
        4 再把结果和第5个元素计算:f(16, 9),结果为25;
        5 由于没有更多的元素了,计算结束,返回结果25。
    
    上述计算实际上是对 list 的所有元素求和。虽然Python内置了求和函数sum(),但是,利用reduce()求和也很简单。
    
    reduce()还可以接收第3个可选参数,作为计算的初始值。如果把初始值设为100,计算:
    
        1 reduce(f, [1, 3, 5, 7, 9], 100)
    
    结果将变为125,因为第一轮计算是:
    
    计算初始值和第一个元素:f(100, 1),结果为101。
    '''
  • 相关阅读:
    批量备份mysql数据库(shell编程)
    批量检查多个网址是否正常(shell编程)
    就linux三剑客简单归纳
    sql语句浅谈以及mysql遇到的问题解决见解
    linux shell每天一阅 -- 安装nginx以及apache
    Linux文件系统检查错误
    Linux账号管理和ACL
    简书博客
    Block内的强引用
    一次没有意义的优化
  • 原文地址:https://www.cnblogs.com/nly666/p/14633163.html
Copyright © 2011-2022 走看看