IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

从代码看不同层次程序员的进化

外刊IT评论 2011-02-08 23:37:38 累计浏览 5,604 次
本机暂存

本文是从 The Evolution of a Python Programmer 这篇文章翻译而来。

不久前,在互联网上出现了一篇有趣的文章,讲的是对于同一个问题,不同层次的程序员编出的Phthon代码显示出了不同的风格,代码都很简单,有趣。这篇文章的原始出处在这里,我把它整理了一下,并修改了几处错误。

编程新手

1
2
3
4
5
6
def factorial(x):
    if x == 0:
        return 1
    else:
        return x * factorial(x - 1)
print factorial(6)

一年编程经验(学Pascal的)

1
2
3
4
5
6
7
8
def factorial(x):
    result = 1
    i = 2
    while i <= x:
        result = result * i
        i = i + 1
    return result
print factorial(6)

一年编程经验(学C的)

1
2
3
4
5
6
7
8
9
def fact(x): #{
    result = i = 1;
    while (i <= x): #{
        result *= i;
        i += 1;
    #}
    return result;
#}
print(fact(6))

一年编程经验(读过 SICP)

1
2
3
4
5
@tailcall
def fact(x, acc=1):
    if (x > 1): return (fact((x - 1), (acc * x)))
    else:       return acc
print(fact(6))

一年编程经验(Python)

1
2
3
4
5
6
def Factorial(x):
    res = 1
    for i in xrange(2, x + 1):
        res *= i
    return res
print Factorial(6)

懒惰的Python程序员

1
2
3
def fact(x):
    return x > 1 and x * fact(x - 1) or 1
print fact(6)

更懒的Python程序员

1
2
f = lambda x: x and x * f(x - 1) or 1
print f(6)

Python 专家

1
2
fact = lambda x: reduce(int.__mul__, xrange(2, x + 1), 1)
print fact(6)

Python 黑客

1
2
3
4
5
6
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')

专家级程序员

1
2
from c_math import fact
print fact(6)

大英帝国程序员

1
2
from c_maths import fact
print fact(6)

Web 设计人员

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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 程序员

1
2
3
4
import os
def fact(x):
    os.system('factorial ' + str(x))
fact(6)

Windows 程序员

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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)

企业级程序员

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
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))

同分类推荐文章

  1. 一个冷门的速查日历方法 (2026-05-27 16:22:00)
  2. Stack Overflow: When We Stop Asking (2026-05-20 21:51:34)
  3. Use Obsidian Sync on Desktop without Installing Obsidian (2026-03-27 00:00:00)

查看更多 开发者 文章 →

建议继续学习

  1. 用Hyer来进行网站的抓取 (累计阅读 158,163)
  2. 配置Nginx+uwsgi更方便地部署python应用 (累计阅读 106,970)
  3. 程序员技术练级攻略 (累计阅读 35,185)
  4. python实现自动登录discuz论坛 (累计阅读 32,722)
  5. python编程细节──遍历dict的两种方法比较 (累计阅读 20,282)
  6. 每个程序员都应该学习使用Python或Ruby (累计阅读 17,823)
  7. 再次写给我们这些浮躁的程序员 (累计阅读 17,085)
  8. Chrome和goagent的配置方法,你懂的 (累计阅读 16,682)
  9. 哪本书是对程序员最有影响、每个程序员都该阅读的书? (累计阅读 15,022)
  10. 30分钟3300%性能提升――python+memcached网页优化小记 (累计阅读 13,662)