aboutsummaryrefslogtreecommitdiff
path: root/challenge-269/deadmarshal/modula-3/ch2/src/Ch2.m3
blob: b785695583861c6b31df6917d5eae0e976281c1e (plain)
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
MODULE Ch2 EXPORTS Main;

IMPORT SIO,IntSeq,Stdio;

EXCEPTION NotEnoughElements;

VAR 
  A1:ARRAY[0..4] OF CARDINAL := ARRAY OF CARDINAL{2,1,3,4,5};
  A2:ARRAY[0..2] OF CARDINAL := ARRAY OF CARDINAL{3,2,4};
  A3:ARRAY[0..3] OF CARDINAL := ARRAY OF CARDINAL{5,4,3,8};

PROCEDURE DistributeElements(VAR A:ARRAY OF CARDINAL):IntSeq.T
  RAISES{NotEnoughElements} =
  VAR
    I:INTEGER := FIRST(A)+2;
    Ret1,Ret2:IntSeq.T := NEW(IntSeq.T).init();
  BEGIN
    IF NUMBER(A) < 2 THEN RAISE NotEnoughElements END;
    Ret1.addhi(A[FIRST(A)]);
    Ret2.addhi(A[FIRST(A)+1]);
    WHILE(I # NUMBER(A)) DO
      IF Ret1.gethi() > Ret2.gethi() THEN Ret1.addhi(A[I])
      ELSE Ret2.addhi(A[I])
      END;
      INC(I)
    END;
    RETURN IntSeq.Cat(Ret1,Ret2)
  END DistributeElements;

PROCEDURE PrintSequence(READONLY Seq:IntSeq.T) =
  BEGIN
    FOR I := 0 TO Seq.size()-1 DO
      SIO.PutInt(Seq.get(I));
      SIO.PutChar(' ')
    END;
    SIO.Nl()
  END PrintSequence;
  
BEGIN
  TRY
    PrintSequence(DistributeElements(A1));
    PrintSequence(DistributeElements(A2));
    PrintSequence(DistributeElements(A3));
  EXCEPT
    NotEnoughElements =>
    SIO.PutText("Not enough elements in array!\n",Stdio.stderr)
  ELSE SIO.PutText("Some other exception occurred!\n",Stdio.stderr)
  END;
END Ch2.