-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathp10.cbl
45 lines (39 loc) · 1.21 KB
/
p10.cbl
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
* PROJECT EULER PROBLEM 10 IN COBOL
IDENTIFICATION DIVISION.
PROGRAM-ID. P10.
AUTHOR. JARED KRINKE.
ENVIRONMENT DIVISION.
DATA DIVISION.
WORKING-STORAGE SECTION.
77 N PIC S9(8) COMP.
77 MULT PIC S9(8) COMP.
77 CNT PIC S9(8) COMP.
77 TOTAL PIC S9(15) COMP VALUE ZERO.
01 ARRAY.
05 CMPS PIC S9(8) COMP VALUE ZERO OCCURS 2000000 TIMES.
PROCEDURE DIVISION.
* MARK ALL MULTIPLES AS COMPOSITE NUMBERS
DISPLAY 'COMPUTING PRIMES...'
SET N TO 2
PERFORM 1000000 TIMES
SET MULT TO N
ADD N TO MULT
PERFORM UNTIL MULT >= 2000000
SET CMPS(MULT) TO 1
ADD N TO MULT
END-PERFORM
ADD 1 TO N
END-PERFORM
* SUM PRIMES
DISPLAY 'ADDING UP PRIMES...'
SET TOTAL TO ZERO
SET N TO 2
PERFORM UNTIL N >= 2000000
IF CMPS(N) = 0 THEN
ADD N TO TOTAL
END-IF
ADD 1 TO N
END-PERFORM
* DISPLAY RESULT
DISPLAY TOTAL
STOP RUN.