mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 10:44:55 +00:00 
			
		
		
		
	 8bef554cf7
			
		
	
	
		8bef554cf7
		
	
	
	
	
		
			
			svn+ssh://pythondev@svn.python.org/python/trunk ........ r75325 | georg.brandl | 2009-10-10 23:55:11 +0200 (Sa, 10 Okt 2009) | 1 line Modernize factorisation demo (mostly augassign.) ........
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
| #! /usr/bin/env python
 | |
| 
 | |
| # Factorize numbers.
 | |
| # The algorithm is not efficient, but easy to understand.
 | |
| # If there are large factors, it will take forever to find them,
 | |
| # because we try all odd numbers between 3 and sqrt(n)...
 | |
| 
 | |
| import sys
 | |
| from math import sqrt
 | |
| 
 | |
| def fact(n):
 | |
|     if n < 1:
 | |
|         raise ValueError('fact() argument should be >= 1')
 | |
|     if n == 1:
 | |
|         return []  # special case
 | |
|     res = []
 | |
|     # Treat even factors special, so we can use i += 2 later
 | |
|     while n % 2 == 0:
 | |
|         res.append(2)
 | |
|         n //= 2
 | |
|     # Try odd numbers up to sqrt(n)
 | |
|     limit = sqrt(n+1)
 | |
|     i = 3
 | |
|     while i <= limit:
 | |
|         if n % i == 0:
 | |
|             res.append(i)
 | |
|             n //= i
 | |
|             limit = sqrt(n+1)
 | |
|         else:
 | |
|             i += 2
 | |
|     if n != 1:
 | |
|         res.append(n)
 | |
|     return res
 | |
| 
 | |
| def main():
 | |
|     if len(sys.argv) > 1:
 | |
|         source = sys.argv[1:]
 | |
|     else:
 | |
|         source = iter(input, '')
 | |
|     for arg in source:
 | |
|         try:
 | |
|             n = int(arg)
 | |
|         except ValueError:
 | |
|             print(arg, 'is not an integer')
 | |
|         else:
 | |
|             print(n, fact(n))
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     main()
 |