Python.use(better) #prime: step02 -- if n<2: return r

記事一覧 Python.use(better)《Python3.1》

prime: step02 -- if n<2: return r

《著》森こねこ、小粒ちゃん+∞《監修》小泉ひよ子とタマゴ倶楽部
第0版♪2001/03/02 ● 第1版♪2003/05/25 ● 第2版♪2004/06/01 ● 第3版♪2009/02/28

課題を作成する過程を通して「数値演算」の理解を深めます。
※ Python1.5 で作成した例題を、Python3.1 で再構成しました。

事例:コードの解説

    from math import sqrt

    def isPrime(n):
        r = False
        if n<2: return r
        m = int(sqrt(n))
        for e in range(2, m+1):
            if not n%e: break
        else:
            r = True
        return r
■ #1: if 文
        if n<2: return r

if に続く条件式 n<2 を満たすときには、変数 r の値をリターン値にします。

  • 変数 n の値が 2 未満なら、素数ではないので、False をリターン値にします。

事例:モジュールを起動する

■ 全項目を確認する

全ステップの「項目」を確認するには、関数 do を利用します。

$ python -i prime.py
>>> do()
0: step00x -- def prime(n):
1: step01x -- if not n%e: break
2: step02 -- if n<2: return r
3: step03 -- def prime(n):
4: step04 -- [e for e in range(n) if isPrime(e)]
5: step05 -- def filter(seq):
6: step06 -- [e for e in rest if e%first]
>>>
■ 各項目を実行する

各ステップの「動作」を確認するには、関数 do に実引数を指定します。

>>> do(2)
>>> # -------------------------------------------------- step02
>>> for e in range(30):
    if isPrime(e): print(e,end=",")
else:
    print("#")

2,3,5,7,11,13,17,19,23,29,#
>>>

30 未満の素数を列挙するとともに、各項目が「,」で区切られて出力されることを確認します。

  • 末尾に # を出力することで、すべてを出力したことが分かります。

《余録》テストケース

def ex_isPrime(local, n):
    source = (
'''for e in range({0}):
    if isPrime(e): print(e,end=",")
else:
    print("#")
'''.format(n),
)
    for e in source:
        print_(e, local)

》こちらに移動中です《
TOP


関連記事

Last updated♪2009/11/10