Я написал код GNU Fortran в двух отдельных файлах по коду :: Блоки: main.f95, example.f95. Содержание main.f95: содержаниеФортран: вызов других функций в функции
program testing
use example
implicit none
integer :: a, b
write(*,"(a)", advance="no") "Enter first number: "
read(*,*) a
write(*,"(a)", advance="no") "Enter second number: "
read(*,*) b
write(*,*) factorial(a)
write(*,*) permutation(a, b)
write(*,*) combination(a, b)
end program testing
example.f95:
module example
contains
integer function factorial(x)
implicit none
integer, intent(in) :: x
integer :: product_ = 1, i
if (x < 1) then
factorial = -1
else if (x == 0 .or. x == 1) then
factorial = 1
else
do i = 2, x
product_ = product_ * i
end do
factorial = product_
end if
end function factorial
real function permutation(x, y)
implicit none
integer, intent(in) :: x, y
permutation = factorial(x)/factorial(x - y)
end function permutation
real function combination(x, y)
implicit none
integer, intent(in) :: x, y
combination = permutation(x, y)/factorial(y)
end function combination
end module example
Когда я запускаю этот код, выход:
Enter first number: 5
Enter second number: 3
120
0.00000000
0.00000000
функции перестановки и комбинации не работают должным образом. Спасибо за ответы.
Это то, что удивляет многих программистов на C/C++. 'integer :: i = 42' НЕ EQUIVALENT для' integer :: i; i = 42', но вместо этого «integer, save :: i = 42'. Значение 'i' поддерживается между вызовами и никогда не сбрасывается до 42. – jlokimlin