Télécharger ordo12.eso

Retour à la liste

Numérotation des lignes :

ordo12
  1. C ORDO12 SOURCE CHAT 05/01/13 02:05:52 5004
  2. SUBROUTINE ORDO12 (MLIST,LLIST,CROISS)
  3. ************************************************************************
  4. *
  5. * O R D O 1 2
  6. * -----------
  7. *
  8. * FONCTION:
  9. * ---------
  10. *
  11. * ORDONNER LE CONTENU D'UN TABLEAU UNICOLONNE D'ENTIERS EN NE TENANT
  12. * COMPTE QUE DES VALEURS ABSOLUES.
  13. *
  14. * MODE D'APPEL:
  15. * -------------
  16. *
  17. * CALL ORDO12 (MLIST,LLIST,CROISS)
  18. *
  19. * PARAMETRES: (E)=ENTREE (S)=SORTIE
  20. * -----------
  21. *
  22. * MLIST ENTIER (E) TABLEAU UNICOLONNE A REORDONNER.
  23. * (S) MEME TABLEAU, AVEC LES ELEMENTS REORDONNES.
  24. * LLIST ENTIER (E) DIMENSION DE "MLIST".
  25. * CROISS LOGIQUE (E) INDIQUE PAR "VRAI" OU "FAUX" SI LE TABLEAU
  26. * DOIT ETRE REORDONNE EN ORDRE CROISSANT.
  27. * SINON, CE SERA FAIT EN ORDRE DECROISSANT.
  28. *
  29. * AUTEUR, DATE DE CREATION:
  30. * -------------------------
  31. *
  32. * PASCAL MANIGOT 23 AVRIL 1985
  33. *
  34. * NOUVEL ALGORITHME PLUS PERFORMANT LE 14 MAI 1985 (P. MANIGOT)
  35. *
  36. * LANGAGE:
  37. * --------
  38. *
  39. * FORTRAN77
  40. *
  41. ************************************************************************
  42. *
  43. IMPLICIT INTEGER(I-N)
  44. INTEGER MLIST(*)
  45. *
  46. LOGICAL CROISS,DECROI
  47. *
  48. DECROI = .NOT.CROISS
  49. *
  50. DO 100 IB100=2,LLIST
  51. *
  52. ML100 = MLIST(IB100)
  53. ML100A = ABS(ML100)
  54. IB101 = IB100 - 1
  55. *
  56. NRANG = IB100
  57. DO 110 IB110=IB101,1,-1
  58. ML110A = ABS(MLIST(IB110))
  59. IF ( (CROISS .AND. ML100A.LT.ML110A)
  60. & .OR. (DECROI .AND. ML100A.GT.ML110A) ) THEN
  61. NRANG = NRANG - 1
  62. ELSE
  63. * --> SORTIE DE BOUCLE N.110
  64. GOTO 112
  65. END IF
  66. 110 CONTINUE
  67. * END DO
  68. 112 CONTINUE
  69. *
  70. DO 120 IB120=IB101,NRANG,-1
  71. MLIST(IB120+1) = MLIST(IB120)
  72. 120 CONTINUE
  73. * END DO
  74. MLIST(NRANG) = ML100
  75. *
  76. 100 CONTINUE
  77. * END DO
  78. *
  79. END
  80.  
  81.  

© Cast3M 2003 - Tous droits réservés.
Mentions légales