|
| 1 | + IDENTIFICATION DIVISION. |
| 2 | + PROGRAM-ID. DIAMOND. |
| 3 | + AUTHOR. kapitaali. |
| 4 | + ENVIRONMENT DIVISION. |
| 5 | + DATA DIVISION. |
| 6 | + WORKING-STORAGE SECTION. |
| 7 | + 01 WS-INPUTVARS. |
| 8 | + 05 WS-LETTER PIC X. |
| 9 | + 05 WS-ROWS PIC 99. |
| 10 | + 01 WS-OUTPUTTABLE. |
| 11 | + 05 WS-TABLEROW OCCURS 1 TO 60 DEPENDING ON WS-ROWS. |
| 12 | + 10 WS-LINE PIC X(60). |
| 13 | + |
| 14 | + 01 MY-WORKVARS. |
| 15 | + 05 CHARS PIC X(26) VALUE 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'. |
| 16 | + 05 ALINE PIC X(60). |
| 17 | + 05 MIDDLEPOINT PIC 99. |
| 18 | + 05 A PIC 99. |
| 19 | + 05 B PIC 99. |
| 20 | + 05 C PIC 99. |
| 21 | + 05 D PIC 99. |
| 22 | + 05 COUNTER PIC 99. |
| 23 | + 05 ADD-THIS PIC S99. |
| 24 | + |
| 25 | + |
| 26 | + PROCEDURE DIVISION. |
| 27 | + |
| 28 | + GET-TABLE-SIZE. |
| 29 | + PERFORM VARYING A FROM 1 BY 1 UNTIL A = 27 |
| 30 | + IF CHARS(A:1) = WS-LETTER |
| 31 | + EXIT PARAGRAPH |
| 32 | + END-IF |
| 33 | + END-PERFORM. |
| 34 | + |
| 35 | + |
| 36 | + DIAMOND. |
| 37 | + EVALUATE WS-LETTER |
| 38 | + WHEN 'A' |
| 39 | + MOVE 1 TO WS-ROWS |
| 40 | + INITIALIZE WS-OUTPUTTABLE |
| 41 | + MOVE 'A' TO WS-TABLEROW(1) |
| 42 | + WHEN 'B' |
| 43 | + MOVE 3 TO WS-ROWS |
| 44 | + INITIALIZE WS-OUTPUTTABLE |
| 45 | + MOVE " A " TO WS-TABLEROW(1) |
| 46 | + MOVE "B B" TO WS-TABLEROW(2) |
| 47 | + MOVE " A " TO WS-TABLEROW(3) |
| 48 | + WHEN OTHER |
| 49 | + PERFORM GET-TABLE-SIZE |
| 50 | + COMPUTE WS-ROWS = 2 + 2*(A - 2) + 1 |
| 51 | + COMPUTE MIDDLEPOINT = (WS-ROWS - 1) / 2 |
| 52 | + INITIALIZE WS-OUTPUTTABLE |
| 53 | + MOVE SPACES TO ALINE |
| 54 | + COMPUTE D = MIDDLEPOINT + 1 |
| 55 | + MOVE CHARS(1:1) TO ALINE(D:1) |
| 56 | + MOVE ALINE TO WS-TABLEROW(1) |
| 57 | + MOVE ALINE TO WS-TABLEROW(WS-ROWS) |
| 58 | + MOVE 0 TO COUNTER |
| 59 | + MOVE 1 TO ADD-THIS |
| 60 | + PERFORM VARYING A FROM 2 BY 1 UNTIL A = WS-ROWS |
| 61 | + MOVE SPACES TO ALINE |
| 62 | + IF COUNTER = MIDDLEPOINT |
| 63 | + MOVE -1 TO ADD-THIS |
| 64 | + END-IF |
| 65 | + COMPUTE COUNTER = COUNTER + ADD-THIS |
| 66 | + COMPUTE B = MIDDLEPOINT - COUNTER |
| 67 | + COMPUTE C = COUNTER + 1 |
| 68 | + COMPUTE D = B + 1 |
| 69 | + MOVE CHARS(C:1) TO ALINE(D:1) |
| 70 | + COMPUTE B = MIDDLEPOINT + COUNTER |
| 71 | + COMPUTE C = COUNTER + 1 |
| 72 | + COMPUTE D = B + 1 |
| 73 | + MOVE CHARS(C:1) TO ALINE(D:1) |
| 74 | + MOVE ALINE TO WS-TABLEROW(A) |
| 75 | + END-PERFORM |
| 76 | + END-EVALUATE. |
| 77 | + |
0 commit comments