您的位置:首页 > 编程语言 > Python开发

CodeWars---Python第三题

2016-07-20 17:00 573 查看

1. 问题描述

2. 代码

3. 总结

[b]一、问题描述:[/b]

Given two integers, which can be positive and negative, find the sum of all the numbers between including them too and return it. If both numbers are equal return a or b.

[b]二、代码:[/b]

1. my solution

def get_sum(a,b):
if a==b:
return a
else:
get_big = max([a,b])
get_small = min([a,b])
nums = xrange(get_small,get_big+1)
return sum(nums)


2. other solutions

def get_sum1(a,b):
return sum(xrange(min(a,b), max(a,b)+1))


def get_sum2(a, b):
return (a + b) * (abs(a - b) + 1) // 2


[b]三、总结[/b]

在python2中,
range()
xrange()
用法相同,但
range()
返回一个list,
xrange()
返回一个xrange Object,是iterable的;

xrange()
占用占用更少的内存空间,因为循环时
xrange()
只生成当前的元素,不像
range()
一开始就生成list;

在python3中,
range()
被移除了,
xrange()
被重新命名为
range()


PS: CodeWars刚开始的题目都不是很难得
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: