File: factorial.pcm

package info (click to toggle)
extrema 4.3.6-1
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 19,212 kB
  • ctags: 6,452
  • sloc: cpp: 86,428; sh: 8,229; makefile: 814
file content (86 lines) | stat: -rw-r--r-- 1,408 bytes parent folder | download | duplicates (3)
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
!
! program for calculating all the digits of n! (factorial).
!  (Using Vector_operation)
!
! Deming Li,  1996.3.  in TRIUMF
!
! run:  @Factorial
!
!disable echo
!
!  Select the Number_BASE  (available Bases: 10,100,...,10000000)
!
BASE=1000
!
!  check if n is valid
!
startfactorial:
inquire 'Enter an integer < '//rchar(base) num
if (num=0) then goto endfactorial
N=int(num)
if (N<1) then N=1
if (N>=Base) then
  display 'N must be < '//rchar(Base)
  return
endif
NChar = rchar(N)
!
!  Guess the number of digits (on BASE)
!
M = int(((N+0.5)*log(N+1)-N-0.081+1/(12*(N+1)))/log(Base)+1)
!
! Create and initialize Digits
!
destroy Dg
Dg[1:M]=0
Dg[M]=1
!
!  Do the multiply loop
!
if (N>1) then
  do i = [2:N]
    Dg = mod(Dg*i,Base)+roll(int(Dg*i/Base),-1)
  enddo
endif
!
!  Post process
!
C = 0
do i = [M:1:-1]
  D = Dg[i]+C
  C = int(D/Base)
  Dg[i] = mod(D,Base)
enddo
!
!  Output the result
! 
='------------ Factorial( '//rchar(N)//` ) ------------'
L = log10(Base)+1
Fmt = '%'//char(48+L)//'.0f'
Nj = int(78/L)
Sl = ' '
i = 1
S = rchar(Dg[i]+Base,Fmt)
do j = [2:L]
  if nes(S[j],'0') then goto done
  S[j] = ' '
enddo
done:
Sl = Sl//S[2:L]//','
j = 1
if (M>1) then
  do i = [2:M]
    S = rchar(Dg[i]+Base,Fmt)
    Sl = Sl//S[2:L]//','
    j = j+1
    if (j=Nj) then 
      = Sl[1:#-(i=M)]
      j = 0
      Sl = ' '
    endif
  enddo
endif
if (J>0) then =Sl[1:#-1]
!goto startfactorial
endfactorial: