The program requires me to remove all item for a list, but when doing the test case for it, it only removes one. What would be the problem in this code? Given code: #include "MovieList.h" #include using namespace std; // Constructor function MovieList::MovieList() { top = nullptr; } // Destructor function MovieList::~MovieList() { MovieNode *p = nullptr; while (top->next != nullptr) { p = top; top = top->next; delete p; } delete top; p = nullptr; top = nullptr; } void MovieList::display(ostream &out) { MovieNode *t = top; int pos = 0; // Function to display the movie list while (t != nullptr) { out << pos << ": " << t->title << endl; pos++; t = t->next; } } int MovieList::count() { MovieNode *t = top; int pos = 0; // Counting based off the movie list while (t != nullptr) { pos++; t = t->next; } return pos; } void MovieList::addToTop(string title) { // New node creation MovieNode *p = new MovieNode(); p->title = title; p->next = nullptr; // Relocating the new node to the top of the list p->next = top; top = p; } void MovieList::addToBottom(string title) { // Creating a new node MovieNode *p = new MovieNode(); p->title = title; p->next = nullptr; // What to do if list is empty if (top == nullptr) { top = p; return; } // Relocating newly added node to the bottom of the list MovieNode *t = top; while(t->next != nullptr) // End node is traversing { t = t->next; } t->next = p; } bool MovieList::moveToTop(string title) { // What to do if the given title is already at the top of list if (top->title == title) { return true; } // Searching for the new node and putting it at the top of list if found MovieNode *t = top->next; MovieNode *p = top; while(t != nullptr) { if (t->title == title) { p->next = t->next; t->next = top; top = t; return true; } p = t; t = t->next; } return false; } bool MovieList::remove(int n) { MovieNode *t = top; // If n == 1 i.e. top node if (n == 1) { top = top->next; t->next = nullptr; delete t; } // To remove any other necessary node else { MovieNode *p = nullptr; while(n++) { if ( t == nullptr ) { return false; } if (n == 1) { p->next = t->next; t->next = nullptr; delete t; } else { p = t; t = t->next; } } } return true; } string MovieList::nextLarger(string title) { string nextLarger = ""; MovieNode *t = top; while(t != nullptr) { if (t->title > title) { nextLarger = t->title; break; } t = t->next; } t = top; // Finding the next largest element in list while(t != nullptr) { if (t->title < nextLarger && t->title > title) { nextLarger = t->title; } t = t->next; } return nextLarger; } void MovieList::displaySorted(ostream& out) { string temp = ""; MovieNode *t = top; out << "Sorted List: " << endl; while(t != nullptr) { temp = this->nextLarger(temp); out << temp << " "; t = t->next; } out << endl; }
The program requires me to remove all item for a list, but when doing the test case for it, it only removes one. What would be the problem in this code?
Given code:
#include "MovieList.h"
#include <iostream>
using namespace std;
// Constructor function
MovieList::MovieList() {
top = nullptr;
}
// Destructor function
MovieList::~MovieList() {
MovieNode *p = nullptr;
while (top->next != nullptr) {
p = top;
top = top->next;
delete p;
}
delete top;
p = nullptr;
top = nullptr;
}
void MovieList::display(ostream &out) {
MovieNode *t = top;
int pos = 0;
// Function to display the movie list
while (t != nullptr) {
out << pos << ": " << t->title << endl;
pos++;
t = t->next;
}
}
int MovieList::count() {
MovieNode *t = top;
int pos = 0;
// Counting based off the movie list
while (t != nullptr) {
pos++;
t = t->next;
}
return pos;
}
void MovieList::addToTop(string title) {
// New node creation
MovieNode *p = new MovieNode();
p->title = title;
p->next = nullptr;
// Relocating the new node to the top of the list
p->next = top;
top = p;
}
void MovieList::addToBottom(string title) {
// Creating a new node
MovieNode *p = new MovieNode();
p->title = title;
p->next = nullptr;
// What to do if list is empty
if (top == nullptr) {
top = p;
return;
}
// Relocating newly added node to the bottom of the list
MovieNode *t = top;
while(t->next != nullptr) // End node is traversing
{
t = t->next;
}
t->next = p;
}
bool MovieList::moveToTop(string title) {
// What to do if the given title is already at the top of list
if (top->title == title) {
return true;
}
// Searching for the new node and putting it at the top of list if found
MovieNode *t = top->next;
MovieNode *p = top;
while(t != nullptr) {
if (t->title == title) {
p->next = t->next;
t->next = top;
top = t;
return true;
}
p = t;
t = t->next;
}
return false;
}
bool MovieList::remove(int n) {
MovieNode *t = top;
// If n == 1 i.e. top node
if (n == 1) {
top = top->next;
t->next = nullptr;
delete t;
}
// To remove any other necessary node
else {
MovieNode *p = nullptr;
while(n++) {
if ( t == nullptr ) {
return false;
}
if (n == 1) {
p->next = t->next;
t->next = nullptr;
delete t;
}
else {
p = t;
t = t->next;
}
}
}
return true;
}
string MovieList::nextLarger(string title) {
string nextLarger = "";
MovieNode *t = top;
while(t != nullptr) {
if (t->title > title) {
nextLarger = t->title;
break;
}
t = t->next;
}
t = top;
// Finding the next largest element in list
while(t != nullptr) {
if (t->title < nextLarger && t->title > title) {
nextLarger = t->title;
}
t = t->next;
}
return nextLarger;
}
void MovieList::displaySorted(ostream& out) {
string temp = "";
MovieNode *t = top;
out << "Sorted List: " << endl;
while(t != nullptr) {
temp = this->nextLarger(temp);
out << temp << " ";
t = t->next;
}
out << endl;
}
data:image/s3,"s3://crabby-images/d0c26/d0c26bc7a1ef71da20ee0bfc693625385f7a6c49" alt="Problem: Implement a part of functionality for the Netflix DVD queue. It's a service that allows a user to create a list of desired movies and
then sends DVDS with movies on top of this list to the subscriber one at a a time. A subscriber should be able to create a list of desired
movies and manipulate the order in a movie queue in their account. Your program will implement some of the desired functionality by
storing the list of movie titles in a linked list. You are provided with the following files available in "Downloadable files" section:
• MovieList.h contains a class declaration for the class that represents a list of movies.
• Driver.cpp contains a main function you can use to test your implementation.
You will be responsible for providing the MovieList.cpp file, including the implementation of the MovieList member functions (described
below):
• MovieList and ~MovieList: creates an empty list, and deallocates all the nodes in the list, respectively.
display(ostream& out) Print movie titles from top to bottom, with positions numbered (put a colon and space between the number
and the movie title) one movie per line. Use out << instead of cout <.
count() Returns the number of movie titles in the list
addToTop(string title) Add a movie to the top of the list
addToBottom(string title) Add a movie to the bottom of the list
• moveToTop(string title) Move a movie with given title to position 0 (top)
• remove(int n) Remove a movie at the given position. Return true if successful, false if there is no movie at position n.
nextLarger(string title) Returns the move title (string t) that would come next after the title t in alphabetical order. Hint: use the
algorithm to find the minimum string in a list, but ignore any movie with title t, and any that come before it in alphabetical order.
displaySorted() Use (i.e. call) nextLarger(string) to output the titles in sorted order with positions numbered. Do NOT sort the linked
list, it should remain in the same order. Call nextLarger on the empty string to find the first one.
Input/Output:
Use the provided Driver.cpp file to test your code. I recommend trying to implement one or two functions at a time, and testing them, rather
than implementing all the functions and then trying to debug them all at once.
NOTES:
• Put your code in a file named MovieList.cpp. This is the only file you need to submit for grading.
• Your MovieList.cpp file must compile with the (unchanged) provided files, and pass at least one test case. You may need to use -
std=c++11 to get the code to compile.
• You may re-use code from the NumberList class (available on Canvas under files, and discussed in class)."
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 2 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/7daab/7daab2e89d2827b6568a3205a22fcec2da31a567" alt="Concepts of Database Management"
data:image/s3,"s3://crabby-images/cd999/cd999b5a0472541a1bb53dbdb5ada535ed799291" alt="Prelude to Programming"
data:image/s3,"s3://crabby-images/39e23/39e239a275aed535da3161bba64f5416fbed6c8c" alt="Sc Business Data Communications and Networking, T…"