8.17 LAB: Inventory (linked lists: insert at the front of a list) C++   Given main(), define an InsertAtFront() member function in the InventoryNode class that inserts items at the front of a linked list (after the dummy head node). Ex. If the input is: 4 plates 100 spoons 200 cups 150 forks 200 the output is: 200 forks 150 cups 200 spoons 100 plates   InventoryNode.h #include #include using namespace std; class InventoryNode { private: string item; int numberOfItems; InventoryNode *nextNodeRef; public: //Constructor InventoryNode() { this->item = ""; this->numberOfItems = 0; this->nextNodeRef = NULL; } //Constructor InventoryNode(string itemInit, int numberOfItemsInit) { this->item = itemInit; this->numberOfItems = numberOfItemsInit; this->nextNodeRef = NULL; } //Constructor InventoryNode(string itemInit, int numberOfItemsInit, InventoryNode nextLoc) { this->item = itemInit; this->numberOfItems = numberOfItemsInit; this->nextNodeRef = &nextLoc; } // TODO: Define an insertAtFront() method that inserts a node at the // front of the linked list (after the dummy head node) //Get the next node InventoryNode *GetNext() { return this->nextNodeRef; } //Print node data void PrintNodeData() { cout << this->numberOfItems << " " << this->item << endl; } };   main.ccp   #include "InventoryNode.h" int main() { int count; int numItems; string item; InventoryNode *headNode = new InventoryNode(); InventoryNode *currNode; // Obtain number of items cin >> count; // Get each item and number of each for (int i = 0; i < count; i++) { cin >> item; cin >> numItems; currNode = new InventoryNode(item, numItems); currNode->InsertAtFront(headNode, currNode); } // Print linked list currNode = headNode->GetNext(); while (currNode != NULL) { currNode->PrintNodeData(); currNode = currNode->GetNext(); } return 0; }

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
icon
Concept explainers
Question

8.17 LAB: Inventory (linked lists: insert at the front of a list) C++

 

Given main(), define an InsertAtFront() member function in the InventoryNode class that inserts items at the front of a linked list (after the dummy head node).

Ex. If the input is:

4
plates 100
spoons 200
cups 150
forks 200

the output is:

200 forks
150 cups
200 spoons
100 plates
 
InventoryNode.h

#include <iostream>
#include <string>
using namespace std;

class InventoryNode {
private:
string item;
int numberOfItems;
InventoryNode *nextNodeRef;

public:
//Constructor
InventoryNode() {
this->item = "";
this->numberOfItems = 0;
this->nextNodeRef = NULL;
}

//Constructor
InventoryNode(string itemInit, int numberOfItemsInit) {
this->item = itemInit;
this->numberOfItems = numberOfItemsInit;
this->nextNodeRef = NULL;
}

//Constructor
InventoryNode(string itemInit, int numberOfItemsInit, InventoryNode nextLoc) {
this->item = itemInit;
this->numberOfItems = numberOfItemsInit;
this->nextNodeRef = &nextLoc;
}


// TODO: Define an insertAtFront() method that inserts a node at the
// front of the linked list (after the dummy head node)


//Get the next node
InventoryNode *GetNext() {
return this->nextNodeRef;
}

//Print node data
void PrintNodeData() {
cout << this->numberOfItems << " " << this->item << endl;
}
};

 

main.ccp

 

#include "InventoryNode.h"

int main() {
int count;
int numItems;
string item;

InventoryNode *headNode = new InventoryNode();
InventoryNode *currNode;

// Obtain number of items
cin >> count;

// Get each item and number of each
for (int i = 0; i < count; i++) {
cin >> item;
cin >> numItems;
currNode = new InventoryNode(item, numItems);
currNode->InsertAtFront(headNode, currNode);
}

// Print linked list
currNode = headNode->GetNext();
while (currNode != NULL) {
currNode->PrintNodeData();
currNode = currNode->GetNext();
}

return 0;
}

Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 3 steps

Blurred answer
Knowledge Booster
Types of Linked List
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education