Please help me with this. Please write it in c++. A simulation creates a model of a real-world situation, allowing us to introduce a variety of conditions and observe their effects. For instance, a flight simulator challenges a pilot to respond to varying conditions and measures how well the pilot responds. Simulation is frequently used to measure current business practices, such as the number of checkout lines in a grocery store or the number of tellers in a bank, so that management can determine the fewest number of employees required to meet customer needs. Airlines have been experimenting with different boarding procedures to shorten the entire boarding time, keep the flights on-time, reduce aisle congestion, and make the experience more pleasant for passengers and crew. A late-departing flight can cause a domino effect: the departure gate is tied up and cannot be used by other landing or departing flights, passengers on board the late flight may miss connecting flights and require rebooking and possibly overnight arrangements (meals and lodging), etc., and passengers complain about being late, and/or about having to rearrange their plans. Thus, late flights have a huge operational impact. For this assignment, we will simulate boarding procedures for Airworthy Airlines. The Airline's current procedure is as follows: pre-board in the following order: families with young children or people who need help (e.g., wheelchair) first class and/or business class passengers elite passengers (frequent fliers) and those passengers seated in exit rows conduct general boarding in reverse, from the back of the plane to the front in the following order: rows 23-26 rows 17-22 rows 11-16 rows 5-10 Airworthy is considering revising their boarding procedure such that general boarding is done randomly, meaning the first passenger in line for general boarding is the first passenger to board (i.e., general boarding passengers all have the same priority). Airworthy suspects this random general boarding method will improve the flow of passengers, getting them on board and seated more quickly. It is also less labor-intensive for Airworthy's customer service agents because it significantly reduces the number of boarding announcements required and eliminates confrontations with customers trying to board "out of turn." Note that the revision is to general boarding only. The pre-boarding procedures will not be changed. Here is the main.cpp: include "ArrayMaxHeap.h" #include "HeapException.h" template ArrayMaxHeap::ArrayMaxHeap() : itemCount(0) { items = new T[CAPACITY]; } template ArrayMaxHeap::~ArrayMaxHeap() { delete[] items; } //interface methods template bool ArrayMaxHeap::add(const T& newItem) { if (itemCount >= CAPACITY) throw HeapException("Trying to add to a full heap."); items[itemCount] = newItem; int newNode = itemCount; bool inPlace = false; while (newNode > 0 && !inPlace) { int parent = getParent(newNode); if (items[newNode] < items[parent]) inPlace = true; else { swap (items[newNode], items[parent]); newNode = parent; } }//new node in place itemCount++; return true; } template void ArrayMaxHeap::clear() { itemCount = 0; } template int ArrayMaxHeap::getItemCount() const { return itemCount; } template T ArrayMaxHeap::peek() const { if (isEmpty()) { throw HeapException("Peek called on an empty heap."); } return items[ROOT_INDEX]; } /** * Removes the item in the heap with the highest priority * @return true if successful * @throws HeapException if heap is empty */ template bool ArrayMaxHeap::remove() { if (isEmpty()) throw HeapException("Trying to remove from an empty heap."); else { items[ROOT_INDEX] = items[itemCount - 1]; itemCount--; percolateDown(ROOT_INDEX); } } template bool ArrayMaxHeap::isEmpty() const { return (itemCount == 0); } template void ArrayMaxHeap::percolateDown(int subtree) { if (!isLeaf(subtree)) { int leftChild = getLeftChild(subtree); int maxChild = leftChild; int rightChild = getRightChild(subtree); if (rightChild < itemCount) { //right child exists if (items[rightChild] > items[leftChild]) maxChild = rightChild; } //maxChild has the index of the largest value of 2 children if (items[subtree] < items[maxChild]) { swap(items[subtree], items[maxChild]); percolateDown(maxChild); } } } //private methods template int ArrayMaxHeap::getLeftChild(int currNode) const { return currNode * 2 + 1; } template int ArrayMaxHeap::getRightChild(int currNode) const { return currNode * 2 + 2; } template int ArrayMaxHeap::getParent(int currNode) const { return (currNode - 1) / 2;
Please help me with this. Please write it in c++.
A simulation creates a model of a real-world situation, allowing us to introduce a variety of conditions and observe their effects. For instance, a flight simulator challenges a pilot to respond to varying conditions and measures how well the pilot responds. Simulation is frequently used to measure current business practices, such as the number of checkout lines in a grocery store or the number of tellers in a bank, so that management can determine the fewest number of employees required to meet customer needs.
Airlines have been experimenting with different boarding procedures to shorten the entire boarding time, keep the flights on-time, reduce aisle congestion, and make the experience more pleasant for passengers and crew. A late-departing flight can cause a domino effect:
- the departure gate is tied up and cannot be used by other landing or departing flights,
- passengers on board the late flight may miss connecting flights and require rebooking and possibly overnight arrangements (meals and lodging), etc., and
- passengers complain about being late, and/or about having to rearrange their plans.
Thus, late flights have a huge operational impact.
For this assignment, we will simulate boarding procedures for Airworthy Airlines. The Airline's current procedure is as follows:
- pre-board in the following order:
- families with young children or people who need help (e.g., wheelchair)
- first class and/or business class passengers
- elite passengers (frequent fliers) and those passengers seated in exit rows
- conduct general boarding in reverse, from the back of the plane to the front in the following order:
- rows 23-26
- rows 17-22
- rows 11-16
- rows 5-10
Airworthy is considering revising their boarding procedure such that general boarding is done randomly, meaning the first passenger in line for general boarding is the first passenger to board (i.e., general boarding passengers all have the same priority). Airworthy suspects this random general boarding method will improve the flow of passengers, getting them on board and seated more quickly. It is also less labor-intensive for Airworthy's customer service agents because it significantly reduces the number of boarding announcements required and eliminates confrontations with customers trying to board "out of turn." Note that the revision is to general boarding only. The pre-boarding procedures will not be changed.
Here is the main.cpp:
include "ArrayMaxHeap.h"
#include "HeapException.h"
template <class T>
ArrayMaxHeap<T>::ArrayMaxHeap() : itemCount(0) {
items = new T[CAPACITY];
}
template <class T>
ArrayMaxHeap<T>::~ArrayMaxHeap() {
delete[] items;
}
//interface methods
template <class T>
bool ArrayMaxHeap<T>::add(const T& newItem) {
if (itemCount >= CAPACITY)
throw HeapException("Trying to add to a full heap.");
items[itemCount] = newItem;
int newNode = itemCount;
bool inPlace = false;
while (newNode > 0 && !inPlace) {
int parent = getParent(newNode);
if (items[newNode] < items[parent])
inPlace = true;
else {
swap (items[newNode], items[parent]);
newNode = parent;
}
}//new node in place
itemCount++;
return true;
}
template <class T>
void ArrayMaxHeap<T>::clear() {
itemCount = 0;
}
template <class T>
int ArrayMaxHeap<T>::getItemCount() const {
return itemCount;
}
template <class T>
T ArrayMaxHeap<T>::peek() const {
if (isEmpty()) {
throw HeapException("Peek called on an empty heap.");
}
return items[ROOT_INDEX];
}
/**
* Removes the item in the heap with the highest priority
* @return true if successful
* @throws HeapException if heap is empty
*/
template <class T>
bool ArrayMaxHeap<T>::remove() {
if (isEmpty())
throw HeapException("Trying to remove from an empty heap.");
else {
items[ROOT_INDEX] = items[itemCount - 1];
itemCount--;
percolateDown(ROOT_INDEX);
}
}
template <class T>
bool ArrayMaxHeap<T>::isEmpty() const {
return (itemCount == 0);
}
template <class T>
void ArrayMaxHeap<T>::percolateDown(int subtree) {
if (!isLeaf(subtree)) {
int leftChild = getLeftChild(subtree);
int maxChild = leftChild;
int rightChild = getRightChild(subtree);
if (rightChild < itemCount) {
//right child exists
if (items[rightChild] > items[leftChild])
maxChild = rightChild;
}
//maxChild has the index of the largest value of 2 children
if (items[subtree] < items[maxChild]) {
swap(items[subtree], items[maxChild]);
percolateDown(maxChild);
}
}
}
//private methods
template <class T>
int ArrayMaxHeap<T>::getLeftChild(int currNode) const {
return currNode * 2 + 1;
}
template <class T>
int ArrayMaxHeap<T>::getRightChild(int currNode) const {
return currNode * 2 + 2;
}
template <class T>
int ArrayMaxHeap<T>::getParent(int currNode) const {
return (currNode - 1) / 2;
Trending now
This is a popular solution!
Step by step
Solved in 2 steps