питон
Ниже приведена версия решения на Python, которая не ограничивается 32-разрядным (или 64-разрядным в самой современной системе) пределом для целых чисел в Python. Чтобы обойти это ограничение, мы будем использовать строку в качестве входных и выходных данных для
factorial
подпрограммы и внутренне разбивать строку на ее цифры, чтобы иметь возможность выполнять умножение.
Итак, вот код: getDigits
функция разбивает строку, представляющую число, на его цифры, поэтому «1234» становится [ 4, 3, 2, 1 ]
(обратный порядок только упрощает функции increase
и multiply
). increase
Функция принимает такой список есть и увеличивает его на единицу. Как следует из названия, multiply
функция умножается, например, multiply([2, 1], [3])
возвращает, [ 6, 3 ]
потому что 12 умножить на 3 равно 36. Это работает так же, как если бы вы умножали что-то ручкой и бумагой.
Затем, наконец, factorial
функция использует эти вспомогательные функции для вычисления фактического факториала, например, factorial("9")
дает в "362880"
качестве своего вывода.
import copy
def getDigits(n):
digits = []
for c in n:
digits.append(ord(c) - ord('0'))
digits.reverse()
return digits
def increase(d):
d[0] += 1
i = 0
while d[i] >= 10:
if i == len(d)-1:
d.append(0)
d[i] -= 10
d[i+1] += 1
i += 1
def multiply(a, b):
subs = [ ]
s0 = [ ]
for bi in b:
s = copy.copy(s0)
carry = 0
for ai in a:
m = ai * bi + carry
s.append(m%10)
carry = m//10
if carry != 0:
s.append(carry)
subs.append(s)
s0.append(0)
done = False
res = [ ]
termsum = 0
pos = 0
while not done:
found = False
for s in subs:
if pos < len(s):
found = True
termsum += s[pos]
if not found:
if termsum != 0:
res.append(termsum%10)
termsum = termsum//10
done = True
else:
res.append(termsum%10)
termsum = termsum//10
pos += 1
while termsum != 0:
res.append(termsum%10)
termsum = termsum//10
return res
def factorial(x):
if x.strip() == "0" or x.strip() == "1":
return "1"
factorial = [ 1 ]
done = False
number = [ 1 ]
stopNumber = getDigits(x)
while not done:
if number == stopNumber:
done = True
factorial = multiply(factorial, number)
increase(number)
factorial.reverse()
result = ""
for c in factorial:
result += chr(c + ord('0'))
return result
print factorial("9")
Примечания
В Python целое число не имеет ограничения, поэтому, если вы хотите сделать это вручную, вы можете просто сделать
fac = 1
for i in range(2,n+1):
fac *= i
Там также очень удобная math.factorial(n)
функция.
Это решение, очевидно, намного сложнее, чем должно быть, но оно действительно работает, и фактически оно иллюстрирует, как вы можете вычислить факториал в случае, если вы ограничены 32 или 64 битами. Поэтому, хотя никто не поверит, что это решение, которое вы придумали для этой простой (по крайней мере, в Python) проблемы, на самом деле вы можете чему-то научиться.