-
Notifications
You must be signed in to change notification settings - Fork 98
/
Copy pathExpenseReport.f
64 lines (60 loc) · 2.22 KB
/
ExpenseReport.f
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
MODULE ExpenseReport
IMPLICIT NONE
ENUM, BIND(C)
ENUMERATOR :: BREAKFAST, DINNER, CAR_RENTAL
ENDENUM
TYPE :: expense
INTEGER :: type
INTEGER :: amount
END TYPE
CONTAINS
SUBROUTINE printReport(expenses)
TYPE(expense), DIMENSION (:), ALLOCATABLE :: expenses
INTEGER :: total = 0
INTEGER :: mealExpenses = 0
INTEGER :: i
CHARACTER(LEN = 20) :: expenseName
CHARACTER(LEN = 1) :: mealOverExpensesMarker
PRINT "(a)", 'Expenses'
DO i = LBOUND(expenses, 1), UBOUND(expenses, 1)
IF (expenses(i)%type == BREAKFAST .OR. expenses(i)%type == DINNER) &
mealExpenses = mealExpenses + expenses(i)%amount
SELECT CASE (expenses(i)%type)
CASE (DINNER)
expenseName = "Dinner"
CASE (BREAKFAST)
expenseName = "Breakfast"
CASE (CAR_RENTAL)
expenseName = "Car Rental"
END SELECT
IF (expenses(i)%type == BREAKFAST .AND. expenses(i)%amount > 1000 .OR. &
expenses(i)%type == DINNER .AND. expenses(i)%amount > 5000) THEN
mealOverExpensesMarker = "X"
ELSE
mealOverExpensesMarker = " "
END IF
total = total + expenses(i)%amount
PRINT "(a,1x,i10,1x,a)", expenseName, expenses(i)%amount, mealOverExpensesMarker
END DO
PRINT "(a,i10)", 'Meal expenses: ', mealExpenses
PRINT "(a,i10)", 'Total: ', total
END SUBROUTINE printReport
END MODULE ExpenseReport
PROGRAM main
USE ExpenseReport
IMPLICIT NONE
TYPE(expense), DIMENSION (:), ALLOCATABLE :: expenses
ALLOCATE(expenses(5))
expenses(1)%type = BREAKFAST
expenses(1)%amount = 1000
expenses(2)%type = BREAKFAST
expenses(2)%amount = 1001
expenses(3)%type = DINNER
expenses(3)%amount = 5000
expenses(4)%type = DINNER
expenses(4)%amount = 5001
expenses(5)%type = CAR_RENTAL
expenses(5)%amount = 4
CALL printReport(expenses)
DEALLOCATE(expenses)
END PROGRAM main