Ê¿À®£¸Ç¯ÅÙ ½©´ü ÂèÆó¼ï ¸á¸å Ìä8

¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡¡Î¹¹¿·Æü¡Ï1996.11.19
Ìä8 ¼¡¤ÎCOBOL¥×¥í¥°¥é¥à¤ÎÀâÌÀµÚ¤Ó¥×¥í¥°¥é¥à¤òÆɤó¤Ç¡¤ÀßÌä¤ËÅú¤¨¤è¡£ ¡Ì¥×¥í¥°¥é¥à¤ÎÀâÌÀ¡Í ¸òÄÌÈñÅù¤Î¸½¶â»Ùµë¤Î¤¿¤á¤Î·ÐÈñ»Ùµë¥Õ¥¡¥¤¥ë¤¬¤¢¤ë¡£¤³¤Î·ÐÈñ»Ùµë¥Õ¥¡¥¤¥ë¤«¤é¡¤ ¼Ò°÷Ê̤˸½¶â»Ùµë³Û¤Ë±þ¤¸¤¿³Æ¶â¼ï¤ÎɬÍ׿ô¤ò°õ»ú¤¹¤ë¡£ ¡Ê1¡Ë·ÐÈñ»Ùµë¥Õ¥¡¥¤¥ë¤Î¥ì¥³¡¼¥ÉÍͼ°¤Ï¡¤¼¡¤Î¤È¤ª¤ê¤Ç¤¢¤ë¡£ ¨£¨¡¨¡¨¡¨¡¨¡¨¨¨¡¨¡¨¡¨¡¨¡¨¨¨¡¨¡¨¡¨¡¨¡¨¨¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¤ ¨¢ ¼Ò°÷ÈÖ¹æ ¨¢ÉôÌ祳¡¼¥É¨¢¸½¶â»Ùµë³Û¨¢ ¤½¤Î¾¤Î¾ðÊó ¨¢ ¨¢ X¡Ê12¡Ë ¨¢ X¡Ê2¡Ë ¨¢ 9¡Ê8¡Ë ¨¢ X¡Ê78¡Ë ¨¢ ¨¦¨¡¨¡¨¡¨¡¨¡¨ª¨¡¨¡¨¡¨¡¨¡¨ª¨¡¨¡¨¡¨¡¨¡¨ª¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¡¨¥ ¡Ê2¡Ë·ÐÈñ»Ùµë¥Õ¥¡¥¤¥ë¤Ï¡¤ÉôÌ祳¡¼¥É¡¤¼Ò°÷ÈÖ¹æ¤Î¾º´è¤ËÀ°Î󤵤ì¤Æ¤¤¤ë¡£ ¡Ê3¡Ë·ÐÈñ»Ùµë¥Õ¥¡¥¤¥ë¤Î¸½¶â»Ùµë³Û¤Ï¡¤0¤è¤êÂ礭¤¤À°¿ô¤È¤¹¤ë¡£ ¡Ê4¡Ë·ÐÈñ»Ùµë¥Õ¥¡¥¤¥ë¤Ë¤Ï¡¤1·ï°Ê¾å¤Î¥Ç¡¼¥¿¤¬¤¢¤ë¡£ ¡Ê5¡Ë°õ»úÍͼ°¤Ï¡¤¼¡¤Î¤È¤ª¤ê¤Ç¤¢¤ë¡£ ©£1, ³Æ¶â¼ï¤Î»ÙµëËç¿ô¤ò¼Ò°÷¤´¤È¤Ë°õ»ú¤¹¤ë¡£ÉôÌçÊ̤ιç·×µÚ¤ÓÁí·×¤â°õ»ú¤¹¤ë¡£ ©¢2, Ʊ¤¸ÉôÌ祳¡¼¥É¤¬Â³¤¯¾ì¹ç¤Ï¡¤ºÇ½é¤Î¼Ò°÷¤À¤±ÉôÌ祳¡¼¥É¤ò°õ»ú¤¹¤ë¡£ ©£3, ¸«½Ð¤·¤Î°õ»ú¤Ï¡¤ÀèƬ¤Ë1²ó¤À¤±¤È¤¹¤ë¡£ ©¤4, ³Æ¶â¼ï¤ÎÁíËç¿ô¤Ï¡¤4¤±¤¿°ÊÆâ¤È¤¹¤ë¡£ ¡Ì¥×¥í¥°¥é¥à¡Í DATA DIVISION. FILE SECTION. FD KFIHI-FILE. 01 KEIHI-REC. 02 KEIHI-BANGOU PIC X(l2). 02 KEIHI-BUMON PIC X(02). 02 KEIHI-GAKU PIC 9(08). 02 PIC X(78). FD KINSHU-FILE. 01 KINSEU-REC WORKING-STORAGE SECTION. 01 END-FILE PIC X(03) VALUE SPACE. 01 CON PIC 9(02). 01 HYON PIC 9(01). 01 WORK-BUMON PIC X(02). 01 GAKU PIC 9(08) 01 KIN1. 02 KIN2 OCCURS3. 03 KIN OCCURS 9 PIC 9(04). 01 TBL. 02 TBL1 PIC X(45) VALUE "100000500001000005000010000050000100000500001¡É. 02 REDEFIES TBL1. 03 TBL-GAKU OCCURS 9 PIC 9(05). 01 PRINT-M. 02 PIC X(22) VALUE "¥Ö¥â¥ó¥³¡¼¥É ¥·¥ã¥¤¥ó¥Ð¥ó¥´¥¦". 02 PM-GAKU OCCURS 9 01 PRINT-D. 02 PD-BUMON PIC X(10). 02 PD¡ÝBANGOU PIC X(l2). 02 PD¡ÝKINSHU OCCURS9 PIC ZZ,ZZZ. PROCEDURE DIVISION. MAIN-RTN. OPEN INPUT KEIHI-FILE OUTPUT KINSHU-FILE INITIALIZE KINI PRINT-D. PERFORM VARYING CON FROM 1BY 1 UNTIL CON > 9 MOVE TBL-GAKU(CON) TO PM-GAKU (CON) END-PERFORM. WRITE KINSHU-REC FROM PRINT-M AFTER PAGE. READ KEIHI-FILE AT END MOVE "END" TO END-FILE NOT AT END MOVE KEIHI-BUMON TO WORK-BUMON MOVE "1ST " TO PD-BUMON END-READ. PERFORM UNTIL END-FILE="EUD" IF KEIHI-BUMON NOT=WORK-BUMON THEN ¡Ì a ¡Í PERFORM PRINT-RTN MOVE KEIHI-BUMON TO WORK-BUMON MOVE "1st " TO PD-BUMON END-IF ¡Ì b ¡Í MOVE I TO HYOU PERFORM PRINT-RTN READ KEIHI-FILE AT END MOVE "END" TO END FILE PERFORM PRINT-RTN VARYING HYOU FROM 2 BY 1 UNTIL HYOU > 3 END-READ END-PERFORM. CLOSE KEIHI-FILE KINSHU-FILE STOP RUN. KINSHU-RTN MOVE KEIHI-GAKU TO GAKU. PERFORM VARYING CON FROM 1 BY 1 UNTIL CON > 9 COMPUTE KIN(l CON) = GAKU / TBL-GAKU(CON) COMPUTE GAKU = GAKU - KIN(1 CON) * TBL-GAKU(CON) ¡Ì c ¡Í END-PERFORM. PRINT-RTN. PERFORM VARYING CON FROM 1 BY 1 UNTIL CON > 9 MOVE KIN ( HYOU CON ) TO PD-KINSHU (CON) END-PERFORM ¡Ì d ¡Í WHEN 1 MOVE KEIHI-BANGOU TO PD-BANGOU IF PD-BUMON¡á"1ST " THEN MOVE WORK-BUMON TO PD-BUMON ELSE MOVE SPACE TO PD-BUMON WHEN 2 MOVE SPACE TO PD-BANGOU MOVE "¥Ö¥â¥ó¥±¥¤" TO PD-BUMON PERFORM VARYING CON FROM 1 BY 1 UNTIL CON > 9 COMPUTE KIN(3 CON)=KIN(3 CON) + KIN(2 CON) END-PERFORM ¡Ì e ¡Í WHEN OTHER MOVE "¥½¥¦¥±¥¤" TO PD=BUMON END-EVALUATE WRITE KINSHU-REC FROM PRINT-D AFTER 2. ÀßÌä ¥×¥í¥°¥é¥àÃæ¤Î¡Ì ¡Í¤ËÆþ¤ì¤ëÀµ¤·¤¤Åú¤¨¤ò¡¢²òÅú·²¤ÎÃ椫¤éÁª¥Ù¡£ a¤Ë´Ø¤¹¤ë²òÅú·² ¥¢ MOVE 1 TO CON ¥¤ MOVE 1 TO HYOU ¥¦ MOVE 2 TO CON ¥¨ MOVE 2 TO HYOU ¥ª MOVE 3 TO CON ¥« MOVE 3 TO HYOU b¤Ë´Ø¤¹¤ë²òÅú·² ¥¢ PERFORM KINSHU-RTN ¥¤ PERFORM KINSHU-RTN THRU PRINT-RTN ¥¦ PERFORM KINSHU-RTN VARYING HYOU FROM 1 BY 1 UNTIL HYOU > 2 ¥¨ PERFORM KINSHU-RTN VARYING HYOU FROM 1 BY 1 UNTIL HYOU > 3 ¥ª PERFORM MAIN-RTN ¥« PERFORM PRINT-RTN c¤Ë´Ø¤¹¤ë²òÅú·² ¥¢ COMPUTE KIN(l CON) = (1 CON) + KIN (2 CON) ¥¤ COMPUTE KIN(2 CON) = (2 CON) + KIN (1 CON) ¥¦ COMPUTE KIN(3 CON) = (3 CON) + KIN (1 CON) ¥¨ MOVE KIN (1 CON) TO (2 CON) ¥ª MOVE KIN (1 CON) TO (3 CON) ¥« MOVE KIN (2 CON) TO (3 CON) d¤Ë´Ø¤¹¤ë²òÅú·² ¥¢ EVALUTE CON ¥¤ EVALUTE GAKU ¥¦ EVALUTE HYOU ¥¨ EVALUTE TBL-GAKU(CON) ¥ª EVALUTE TBL-GAKU(HYOU) ¥« EVALUTE WORK-BUMON e¤Ë´Ø¤¹¤ë²òÅú·² ¥¢ INITIALIZE KIN1 ¥¤ INITIALIZE KIN2 (1) ¥¦ INITIALIZE KIN2 (2) ¥¨ INITIALIZE KIN2 (3) ¥ª INITIALIZE PRINT-D ¥« INITIALIZE WORK-BUMON