-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLockerApplicationClass.java
More file actions
124 lines (102 loc) · 3.77 KB
/
LockerApplicationClass.java
File metadata and controls
124 lines (102 loc) · 3.77 KB
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/***************************************************************
* Name : Program Name
* Author: Larry Paucar
* Created : Apr 20, 2023
* Course: CIS 152 - Data Structure
* Version: 1.0
* OS: Windows XX
* IDE: eclipse
* Copyright : This is my own original work
* based on specifications issued by our instructor
* Description : This is the main class for the wine locker application. This class
* implements the use of a linked list as well as a queue for the data
* structures. In this class I have methods to add a member to a wait
* list if no wine lockers are available, a method to assign a locker to
* a member, a method to remove a member off of the wait list, and other methods
* to display information. My project is however unfinished as I did not implement
* the insertion sort that I wanted to implement and I also don't have a interface
* included.
*
*
* Academic Honesty: I attest that this is my original work.
* I have not used unauthorized source code, either modified or
* unmodified. I have not given other fellow student(s) access
* to my program.
***************************************************************
*/
import java.util.LinkedList;
import java.util.Queue;
public class LockerApplicationClass {
private LinkedList<MemberInfo> members;
private Queue<MemberInfo> waitlist;
private WineLockerClass[] lockers;
public LockerApplicationClass(int numLockers, int lockerCapacity) {
members = new LinkedList<>();
waitlist = new LinkedList<>();
lockers = new WineLockerClass[numLockers];
for (int i = 0; i < numLockers; i++) {
lockers[i] = new WineLockerClass(i + 1, lockerCapacity);
}
}
public void addToWaitlist(MemberInfo member) {
waitlist.add(member);
System.out.println("Added " + member + " to the waitlist.");
}
public void assignWineLocker(MemberInfo member) {
boolean found = false;
for (int i = 0; i < lockers.length; i++) {
if (lockers[i].isAvailable()) {
lockers[i].setAvailable(false);
member.setLockerNumber(lockers[i].getNumber());
members.add(member);
System.out.println("Assigned " + member + " to " + lockers[i] + ".");
found = true;
break;
}
}
if (!found) {
System.out.println("No wine locker available. Added " + member + " to the waitlist.");
addToWaitlist(member);
}
}
public void removeMember(MemberInfo member) {
boolean removed = members.remove(member);
if (removed) {
int lockerNumber = member.getLockerNumber();
lockers[lockerNumber - 1].setAvailable(true);
System.out.println("Removed " + member + " from " + lockers[lockerNumber - 1] + ".");
if (!waitlist.isEmpty()) {
MemberInfo next = waitlist.poll();
assignWineLocker(next);
}
} else {
System.out.println("Member not found.");
}
}
public MemberInfo searchMember(String nameOrId) {
for (MemberInfo member : members) {
if (member.getName().equals(nameOrId) || Integer.toString(member.getId()).equals(nameOrId)) { // if the name or ID matches
return member;
}
}
return null;
}
public void displayMembers() {
System.out.println("Members who have wine lockers:");
for (MemberInfo member : members) {
System.out.println(member);
}
}
public void displayWaitlist() {
System.out.println("Members who are in the waitlist:");
for (MemberInfo member : waitlist) {
System.out.println(member);
}
}
public void displayLockers() {
System.out.println("Wine lockers:");
for (WineLockerClass locker : lockers) {
System.out.println(locker);
}
}
}