-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmain.py
258 lines (234 loc) · 8.92 KB
/
main.py
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
from ADT import Game, Review
from Trie import Trie
from AVLTree import AVLTree
from seeds import getGames
from Minheap import MinHeap
from MaxHeap import MaxHeap
from Graph import GameGraph
class GameStore:
def __init__(self):
self.gameAVL = AVLTree()
self.gameHeapRating = MinHeap("rating")
self.gameHeapPrice = MinHeap("price")
self.gameHeapRatingDesc = MaxHeap("rating")
self.gameHeapPriceDesc = MaxHeap("price")
self.gameGraph = GameGraph()
self.gameTrie = Trie()
self.gameNameToId = {}
def getAllGames(self):
return self.gameAVL.inorderTraversal(self.gameAVL.root)
def findGame(self, id):
return self.gameAVL.searchNode(self.gameAVL.root, id)
def insertGame(self, game):
self.gameAVL.root = self.gameAVL.insertGame(self.gameAVL.root, game)
self.gameTrie.insert(game.name)
self.gameNameToId[game.name] = game.id
self.gameHeapPrice.insert(game)
self.gameHeapPriceDesc.insert(game) # Add to descending price heap
self.gameHeapRating.insert(game)
self.gameHeapRatingDesc.insert(game) # Add to descending rating heap
self.gameGraph.add_game(game, game.genre)
for gen in game.genre:
l = len(self.gameGraph.genre_map)
if gen not in self.gameGraph.genre_map.values():
self.gameGraph.genre_map[str(l + 1)] = gen
return
def gameNameSearch(self, gameName):
matchedNames = self.gameTrie.search(gameName)
if isinstance(matchedNames, bool) or not matchedNames:
# If no exact match, try autocomplete
# Using starts_with to check if the game name starts with the input
if self.gameTrie.starts_with(gameName):
matchedNames = self.gameTrie.autocomplete(gameName)
if not matchedNames:
# If no autocomplete results, try autocorrect
matchedNames = self.gameTrie.autocorrect(gameName)
if not matchedNames:
# If no autocorrect results or it doesn't start with the given word, try substring match
matchedNames = self.gameTrie.substring_match(gameName)
#Converting the game name list into game object list
matchedGames = [self.findGame(self.gameNameToId[name]).id for name in matchedNames]
if (len(matchedNames)> 1):
self.gameSelection([self.findGame(self.gameNameToId[name]) for name in matchedNames])
elif (len(matchedNames) == 1):
self.game_info(matchedGames[0])
else:
print("No games found with the entered name")
def sortRating(self, order):
if order == "ascending":
MinH = self.gameHeapRating
sorted_games = MinH.extractSortedGames()
top_10_games = [
sorted_games[0],
sorted_games[1],
sorted_games[2],
sorted_games[3],
sorted_games[4],
sorted_games[5],
sorted_games[6],
sorted_games[7],
sorted_games[8],
sorted_games[9]
]
return top_10_games
elif order == "descending":
return self.gameHeapRatingDesc.extractSortedGames()
return []
def sortPrice(self, order):
if order == "ascending":
MinH = self.gameHeapPrice
sorted_games = MinH.extractSortedGames()
top_10_games = [
sorted_games[0],
sorted_games[1],
sorted_games[2],
sorted_games[3],
sorted_games[4],
sorted_games[5],
sorted_games[6],
sorted_games[7],
sorted_games[8],
sorted_games[9]
]
return top_10_games
elif order == "descending":
return self.gameHeapPriceDesc.extractSortedGames()
return []
def getGenreGames(self,genre):
genbased = self.gameGraph.getGenreGames(genre)
gs = []
for game in genbased:
gs.append(game)
return gs
def gameSelection(self,games):
print("Enter ID to know more about the following games")
print("____________________________________\n")
for i in games:
print(i.id,i.name)
print("Price: ",i.price)
print("Rating: ",i.rating)
print("Genre(s)")
for j in range(0,len(i.genre)):
print(i.genre[j], end=" ")
print("\n")
print("____________________________________")
search_id = int(input())
if(search_id <= id):
self.game_info(search_id)
else:
print("Invalid Game ID")
def game_info(self, gameChoice):
retrievedGame = self.findGame(gameChoice)
if retrievedGame is None:
raise IndexError("Game doesn't exist")
print('Name:', retrievedGame.name)
print('Price:', retrievedGame.price)
print('Rating:', retrievedGame.rating)
print('Genre(s):')
for i in retrievedGame.genre:
print('\t', i)
similar_games = self.gameGraph.similarGames(retrievedGame)
if similar_games:
print("\nSimilar Games: ")
count = min(len(similar_games), 8)
for game_name in range(count):
print("\t", similar_games[game_name])
else:
print("\nNo Similar Games.")
ch = input("Would you like to see the reviews?(Y/N)").upper()
if ch=="Y":
for k,v in retrievedGame.reviews.items():
print("Author:", k)
print("Review:", v)
print()
ch=input("Press any key to go back")
add_review = input("Would you like to add a review for this game? (Y/N)").upper()
if add_review == "Y":
author = input("Enter your name: ")
review = input("Enter your review: ")
retrievedGame.reviews[author] = review
print("Review added successfully!")
else:
print("No review added.")
print()
# Driver Code
gameStore=GameStore()
games = getGames()
for i in games:
gameStore.insertGame(i)
id=37 #We have 37 games in the tree
while True:
print("Welcome to GameStop")
print("Enter the corresponding option number")
print("1. View All Games")
print("2. Search for a game")
print("3. Show top 10 Games by Price")
print("4. Show top 10 Games by Rating")
print("5. Show Games by Genre")
print("6. Add a Game")
print("Press Enter key to exit")
choice=input()
if choice=='':
print("Thank you for stopping by!")
break
choice=int(choice)
if choice==1:
allGames=gameStore.getAllGames()
gameStore.gameSelection(allGames)
elif choice==2:
print("Enter the name of the game")
gameSearch=input()
foundGames=gameStore.gameNameSearch(gameSearch)
if (foundGames):
print("Found Games:",foundGames)
elif choice==3:
print("1. High to Low")
print("2. Low to High")
ch=int(input())
if ch==1:
sortedGames=gameStore.sortPrice("descending")
gameStore.gameSelection(sortedGames)
elif ch==2:
sortedGames = gameStore.sortPrice("ascending")
gameStore.gameSelection(sortedGames)
else:
raise IndexError("Choose correct value")
pass
elif choice==4:
print("1. High to Low")
print("2. Low to High")
ch = int(input())
if ch == 1:
sortedGames = gameStore.sortRating("descending")
gameStore.gameSelection(sortedGames)
elif ch == 2:
sortedGames = gameStore.sortRating("ascending")
gameStore.gameSelection(sortedGames)
else:
raise IndexError("Choose correct value")
pass
elif choice==5:
print("Enter the number next to genre")
for k, v in gameStore.gameGraph.genre_map.items():
print(k, ":", v)
genre_choice = input()
genre = gameStore.gameGraph.genre_map.get(genre_choice)
if genre:
genreGames = gameStore.getGenreGames(genre)
gameStore.gameSelection(genreGames)
else:
print("Invalid genre choice. Please select a valid option.")
elif choice==6:
name=input("Game Name\t:")
price=float(input("Price\t:"))
rating=float(input("Rating\t:"))
genre=input("Genre(separated by space)\t:").split()
for gen in range(len(genre)):
genre[gen] = genre[gen][0].capitalize() + genre[gen][1:]
id += 1
newGame = Game(name, price, genre, rating, id)
gameStore.insertGame(newGame)
print("Successfully added a new game!")
else:
print("Not an option, Thank you for stopping by!")
break