* M01ZAF Example Program Text * Mark 14 Revised. NAG Copyright 1989. * .. Parameters .. INTEGER MMAX, NMAX PARAMETER (MMAX=20,NMAX=20) INTEGER NIN, NOUT PARAMETER (NIN=5,NOUT=6) * .. Local Scalars .. INTEGER I, IFAIL, J, M, N * .. Local Arrays .. DOUBLE PRECISION RM(MMAX,NMAX) INTEGER IPERM(MMAX) * .. External Subroutines .. EXTERNAL M01DEF, M01ZAF * .. Executable Statements .. WRITE (NOUT,*) 'M01ZAF Example Program Results' * Skip heading in data file READ (NIN,*) READ (NIN,*) M, N IF (M.GE.1 .AND. M.LE.MMAX .AND. N.GE.1 .AND. N.LE.NMAX) THEN DO 20 I = 1, M READ (NIN,*) (RM(I,J),J=1,N) 20 CONTINUE IFAIL = 0 * CALL M01DEF(RM,MMAX,1,M,1,N,'Ascending',IPERM,IFAIL) CALL M01ZAF(IPERM,1,M,IFAIL) * WRITE (NOUT,*) WRITE (NOUT,*) 'Matrix sorted by rows' WRITE (NOUT,*) DO 40 I = 1, M WRITE (NOUT,99999) (RM(IPERM(I),J),J=1,N) 40 CONTINUE END IF * 99999 FORMAT (1X,3F7.1) END