Python程序员的进化
以前本站发布过一篇《程序员的进化》,以一种幽默的代码展现方式调侃了程序。下面这篇是关于Python程序员的。以阶乘为例,很有意思。
目录
新手程序员
def factorial(x): if x == 0: return 1 else: return x * factorial(x - 1) print factorial(6)
第一年的刚学完Pascal的新手
def factorial(x): result = 1 i = 2 while i <= x: result = result * i i = i + 1 return result print factorial(6)
第一年的刚学完C语言的新手
def fact(x): #{ result = i = 1; while (i <= x): #{ result *= i; i += 1; #} return result; #} print(fact(6))
第一年刚学完SICP的新手
@tailcall def fact(x, acc=1): if (x > 1): return (fact((x - 1), (acc * x))) else: return acc print(fact(6))
第一年刚学完Python的新手
def Factorial(x): res = 1 for i in xrange(2, x + 1): res *= i return res print Factorial(6)
爱偷懒的程序员
def fact(x): return x > 1 and x * fact(x - 1) or 1 print fact(6)
更懒的 Python 程序员
f = lambda x: x and x * f(x - 1) or 1 print f(6)
Python 专家
import operator as op import functional as f fact = lambda x: f.foldl(op.mul, 1, xrange(2, x + 1)) print fact(6)
Python 黑客
import sys @tailcall def fact(x, acc=1): if x: return fact(x.__sub__(1), acc.__mul__(x)) return acc sys.stdout.write(str(fact(6)) + '\n')
专家级程序员
import c_math fact = c_math.fact print fact(6)
英语系的专家级程序员
import c_maths fact = c_maths.fact print fact(6)
Web 设计者
def factorial(x): #------------------------------------------------- #--- Code snippet from The Math Vault --- #--- Calculate factorial (C) Arthur Smith 1999 --- #------------------------------------------------- result = str(1) i = 1 #Thanks Adam while i <= x: #result = result * i #It's faster to use *= #result = str(result * result + i) #result = int(result *= i) #?????? result str(int(result) * i) #result = int(str(result) * i) i = i + 1 return result print factorial(6)
Unix 程序员
import os def fact(x): os.system('factorial ' + str(x)) fact(6)
Windows 程序员
NULL = None def CalculateAndPrintFactorialEx(dwNumber, hOutputDevice, lpLparam, lpWparam, lpsscSecurity, *dwReserved): if lpsscSecurity != NULL: return NULL #Not implemented dwResult = dwCounter = 1 while dwCounter <= dwNumber: dwResult *= dwCounter dwCounter += 1 hOutputDevice.write(str(dwResult)) hOutputDevice.write('\n') return 1 import sys CalculateAndPrintFactorialEx(6, sys.stdout, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL)
公司里的程序员
def new(cls, *args, **kwargs): return cls(*args, **kwargs) class Number(object): pass class IntegralNumber(int, Number): def toInt(self): return new (int, self) class InternalBase(object): def __init__(self, base): self.base = base.toInt() def getBase(self): return new (IntegralNumber, self.base) class MathematicsSystem(object): def __init__(self, ibase): Abstract @classmethod def getInstance(cls, ibase): try: cls.__instance except AttributeError: cls.__instance = new (cls, ibase) return cls.__instance class StandardMathematicsSystem(MathematicsSystem): def __init__(self, ibase): if ibase.getBase() != new (IntegralNumber, 2): raise NotImplementedError self.base = ibase.getBase() def calculateFactorial(self, target): result = new (IntegralNumber, 1) i = new (IntegralNumber, 2) while i <= target: result = result * i i = i + new (IntegralNumber, 1) return result print StandardMathematicsSystem.getInstance(new (InternalBase, new (IntegralNumber, 2))).calculateFactorial(new (IntegralNumber, 6))
摘自:来源
(转载本站文章请注明作者和出处 酷 壳 – CoolShell ,请勿用于任何商业用途)
《Python程序员的进化》的相关评论
NULL,NULL,NULL,NULL,NULL,NULL,NULL…..
from math import factorial
print factorial(6)
是什么程序员?
机器学习新手(逃
看来我比新手还新。
我不会写哦。。。囧。
坦白说在软件公司我会义无反顾的选择最后一种。
现在我会选择专家级程序员那种,因为坚信自己的C语言能力远不及python解释器
喜欢上这里
最后一个应翻译为“企业级程序员”
> 坦白说在软件公司我会义无反顾的选择最后一种。
如果是公司开发,为什么不选用 #2 说的那种方法呢??
我的第一反映,我是SICP新手 :)
最后一个正解,工资是按代码行数算的。
def facto(n):\n return reduce(lambda x,y:x*y,range(1,n+1))
这个没看到哦,那我属于哪一类
很有趣。
windows程序员那个绝了
1 f = lambda x: x and x * f(x – 1) or 1
我就是这样写的
哦,不巧我今天刚好要写一个阶乘。
楼主的阶乘看似都是用的递归,开销太大,阶乘一般都是用迭代来计算的。
来,我也来写一个:
def fact(n) :
return reduce(lambda x, y: x*y, range(1, (n or 1) +1))
Windows程序员总是被调侃。。。
我最喜欢“Python 专家”的写法。阅读本文之前让我写,我写的会和“第一年的刚学完Pascal的新手”差不多。我是Python新手,本文对我了解Python很有帮助,谢谢!
我曾经也像第一年刚学完Python的新手那样写过。现在的话,第一反应就是打开 Python 文档搜索 factorial
干.
我成了爱偷懒的程序员了..
第一年的刚学完C语言的新手~~
哇unix可以那样写的啊。
f = lambda x:x*f(x-1) if x>1 else 1
print f(6)
第一年学完SICP的新手路过啊~~
很喜欢这个网站 。
我是学过Pascal,的确哈~感觉非常一样,不明白与C有什么区别啊~
fact = lambda n: reduce(lambda a, b: a*b, xrange(1, n+1))
print fact(6)
import operator
def f(n):
return reduce(operator.mul, xrange(1, n+1, 1))
@依云
居然在这里碰到你了。 仙子喵,
陈老师, 你好, 我现在刚开始学Python, 但是不知道大体的学习方向, 能不能给点建议呢
无意中翻到这篇……
import math
dir(math)
# 10 秒钟后……
math.factorial(10)
print reduce(lambda x,y:x*y,range(1,7))