mirror of
https://github.com/python/cpython.git
synced 2025-07-19 17:25:54 +00:00
Initial revision
This commit is contained in:
parent
0481447f41
commit
ec758ead39
16 changed files with 1007 additions and 0 deletions
45
Demo/scripts/fact.py
Executable file
45
Demo/scripts/fact.py
Executable file
|
@ -0,0 +1,45 @@
|
|||
#! /usr/local/python
|
||||
|
||||
# Factorize numbers, slowly.
|
||||
# This version uses plain integers and is thus limited to 2**31-1.
|
||||
|
||||
import sys
|
||||
from math import sqrt
|
||||
|
||||
error = 'fact.error' # exception
|
||||
|
||||
def fact(n):
|
||||
if n < 1: raise error # fact() argument should be >= 1
|
||||
if n = 1: return [] # special case
|
||||
res = []
|
||||
# Treat even factors special, so we can use i = i+2 later
|
||||
while n%2 = 0:
|
||||
res.append(2)
|
||||
n = n/2
|
||||
# Try odd numbers up to sqrt(n)
|
||||
limit = int(sqrt(float(n+1)))
|
||||
i = 3
|
||||
while i <= limit:
|
||||
if n%i = 0:
|
||||
res.append(i)
|
||||
n = n/i
|
||||
limit = int(sqrt(float(n+1)))
|
||||
else:
|
||||
i = i+2
|
||||
res.append(n)
|
||||
return res
|
||||
|
||||
def main():
|
||||
if len(sys.argv) > 1:
|
||||
for arg in sys.argv[1:]:
|
||||
n = int(eval(arg))
|
||||
print n, fact(n)
|
||||
else:
|
||||
try:
|
||||
while 1:
|
||||
n = int(input())
|
||||
print n, fact(n)
|
||||
except EOFError:
|
||||
pass
|
||||
|
||||
main()
|
Loading…
Add table
Add a link
Reference in a new issue