Conversion Nombre Arabe en Nombre Romain

Contenu du snippet

! Fortran 90
 
function romain(n) result(res)
 
  implicit none
  integer, intent (in) :: n
  integer, parameter   :: l = 13
  integer              :: m, p
  character (32)       :: res
  integer, dimension (l), parameter :: tdec = &
    & (/1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1/)
  character (32), dimension (len), parameter :: trom = &
    & (/'M ', 'CM', 'D ', 'CD', 'C ', 'XC', 'L ', 'XL', 'X ', 'IX', 'V ', 'IV', 'I '/)
 
  res = ''
  m = n
  do i = 1, l
    p = m / tdec (i)
    res = trim (r) // repeat (trim (trom (i)), p)
    m = m - tdec (i)*p
  end do
 
end function romain
function niamor(romain) result(res)
  character(*), intent(in) :: romain
  integer :: n, m, res
 
  res = 0
  m = 0
  do i = len(romain), 1, -1
    select case(romain(i:i))
      case ('M')
        n = 1000
      case ('D')
        n = 500
      case ('C')
        n = 100
      case ('L')
        n = 50
      case ('X')
        n = 10
      case ('V')
        n = 5
      case ('I')
        n = 1
      case default
        n = 0
    end select
    if (n < m) then
      res = res - n
    else
      res = res + n
    end if
    m = n
  end do
end function niamor


Compatibilité : Fortran

Disponible dans d'autres langages :

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.