def calc_prod(lst):
def f(x,y):
return x*y
def lazy_prod():
return reduce(f,lst)
return lazy_prod
def f(x,y):
return x*y
def lazy_prod():
return reduce(f,lst)
return lazy_prod
2015-05-13
def prod(x, y):
if x != y:
return x*y
else:
return 1
print reduce(prod, [2, 4, 5, 7, 12])
if x != y:
return x*y
else:
return 1
print reduce(prod, [2, 4, 5, 7, 12])
2015-05-12
查了一下,貌似key的方法也可以,不过楼上有个哥们貌似少写了括号,sorted(s, key=lambda x: x.upper())
2015-05-12
最后加一个分母的判断会比较好。。。
def __str__(self):
g=gcd(self.p,self.q)
if self.q/g ==1:
return '%s'%(self.p/g)
else:
return '%s/%s'%(self.p/g,self.q/g)
def __str__(self):
g=gcd(self.p,self.q)
if self.q/g ==1:
return '%s'%(self.p/g)
else:
return '%s/%s'%(self.p/g,self.q/g)
2015-05-11
def count():
fs = []
for i in range(1, 4):
def x(a=i):
return a**2
fs.append(x)
return fs
这样子折腾好吗
fs = []
for i in range(1, 4):
def x(a=i):
return a**2
fs.append(x)
return fs
这样子折腾好吗
2015-05-11
第一次
def calc_prod(lst):
def x():
c = 1
for b in lst:
c *= b
return c
return x
第二次 查了下lambda 后原来这东西 是匿名函数
def calc_prod(lst):
def x():
return reduce(lambda a,b:a*b, lst)
return x
def calc_prod(lst):
def x():
c = 1
for b in lst:
c *= b
return c
return x
第二次 查了下lambda 后原来这东西 是匿名函数
def calc_prod(lst):
def x():
return reduce(lambda a,b:a*b, lst)
return x
2015-05-11
def cmp_ignore_case(s1, s2):
s1 = s1.lower()
s2 = s2.lower()
if s1 > s2:
return 1
if s1 < s2:
return -1
return 0
s1 = s1.lower()
s2 = s2.lower()
if s1 > s2:
return 1
if s1 < s2:
return -1
return 0
2015-05-11
def is_sqr(x):
return int(math.sqrt(x)) ** 2 == x
呵呵。 sqrt 开方后是浮点数。 所以不能去判断 是否为int,
开平方根是否为整数 可以将结果转成整数,如果不是整数 乘回去 是不等的
return int(math.sqrt(x)) ** 2 == x
呵呵。 sqrt 开方后是浮点数。 所以不能去判断 是否为int,
开平方根是否为整数 可以将结果转成整数,如果不是整数 乘回去 是不等的
2015-05-11
def format_name(s):
return "%s%s" %(s[0].upper(),s[1:].lower())
return "%s%s" %(s[0].upper(),s[1:].lower())
2015-05-11