#ifndef NODES_LLOLL_H #define NODES_LLOLL_H #include    // for ostream namespace CS3358_SP2023_A5P2

C++ Programming: From Problem Analysis to Program Design
8th Edition
ISBN:9781337102087
Author:D. S. Malik
Publisher:D. S. Malik
Chapter18: Stacks And Queues
Section: Chapter Questions
Problem 21SA
icon
Related questions
Question
100%

#ifndef NODES_LLOLL_H
#define NODES_LLOLL_H

#include <iostream>    // for ostream

namespace CS3358_SP2023_A5P2
{
   // child node
   struct CNode
   {
      int data;
      CNode* link;
   };

   // parent node
   struct PNode
   {
      CNode* data;
      PNode* link;
   };

   // toolkit functions for LLoLL based on above node definitions
   void Destroy_cList(CNode*& cListHead);
   void Destroy_pList(PNode*& pListHead);
   void ShowAll_DF(PNode* pListHead, std::ostream& outs);
   void ShowAll_BF(PNode* pListHead, std::ostream& outs);
}

#endif

#include "nodes_LLoLL.h"
#include "cnPtrQueue.h"
#include <iostream>
using namespace std;

namespace CS3358_SP2023_A5P2
{
    
   // do breadth-first (level) traversal and print data
   void ShowAll_BF(PNode* pListHead, ostream& outs)
   {
       cnPtrQueue queue;
      CNode* currentNode;

      queue.push(lloLLPtr->getHead());

      while (!queue.empty())
      {
         currentNode = queue.front();
         queue.pop();

         if (currentNode->dataIsPtr)
         {
            queue.push(currentNode->getDownPtr());
         }
         else
         {
            std::cout << currentNode->getDownData() << "  ";
         }
      }

      std::cout << std::endl;
   }
   
   
   void Destroy_cList(CNode*& cListHead)
   {
      int count = 0;
      CNode* cNodePtr = cListHead;
      while (cListHead != 0)
      {
         cListHead = cListHead->link;
         delete cNodePtr;
         cNodePtr = cListHead;
         ++count;
      }
      cout << "Dynamic memory for " << count << " CNodes freed"
           << endl;
   }

   void Destroy_pList(PNode*& pListHead)
   {
      int count = 0;
      PNode* pNodePtr = pListHead;
      while (pListHead != 0)
      {
         pListHead = pListHead->link;
         Destroy_cList(pNodePtr->data);
         delete pNodePtr;
         pNodePtr = pListHead;
         ++count;
      }
      cout << "Dynamic memory for " << count << " PNodes freed"
           << endl;
   }

   // do depth-first traversal and print data
   void ShowAll_DF(PNode* pListHead, ostream& outs)
   {
      while (pListHead != 0)
      {
         CNode* cListHead = pListHead->data;
         while (cListHead != 0)
         {
            outs << cListHead->data << "  ";
            cListHead = cListHead->link;
         }
         pListHead = pListHead->link;
      }
   }
}

>sh -c make -s
./nodes_LLOLL.cpp:15:18: error: use of undeclared identifier 'lloLLPtr'
queue.push(lloLLPtr->getHead());
./nodes_LLOLL.cpp:22:27: error: no member named 'dataIsPtr' in 'CS3358_SP2023_A5P2::CNode'
if (currentNode->dataIsptr)
NNNNNNNNNNN
./nodes_LLOLL.cpp:24:37: error: no member named 'getDownPtr' in 'CS3358_SP2023_A5P2::CNode'
queue.push(currentNode->get DownPtr());
NNNN
NNNN
./nodes_LLOLL.cpp:28:39: error: no member named 'getDownData' in 'CS3358_SP2023_A5P2::CNode'
std::cout <<< currentNode->getDownData() << " ";
NN
4 errors generated.
make: *** [Makefile:10: main] Error 1
exit status 2
Q Û
Transcribed Image Text:>sh -c make -s ./nodes_LLOLL.cpp:15:18: error: use of undeclared identifier 'lloLLPtr' queue.push(lloLLPtr->getHead()); ./nodes_LLOLL.cpp:22:27: error: no member named 'dataIsPtr' in 'CS3358_SP2023_A5P2::CNode' if (currentNode->dataIsptr) NNNNNNNNNNN ./nodes_LLOLL.cpp:24:37: error: no member named 'getDownPtr' in 'CS3358_SP2023_A5P2::CNode' queue.push(currentNode->get DownPtr()); NNNN NNNN ./nodes_LLOLL.cpp:28:39: error: no member named 'getDownData' in 'CS3358_SP2023_A5P2::CNode' std::cout <<< currentNode->getDownData() << " "; NN 4 errors generated. make: *** [Makefile:10: main] Error 1 exit status 2 Q Û
Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 2 steps

Blurred answer
Knowledge Booster
ListBox
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
  • SEE MORE QUESTIONS
Recommended textbooks for you
C++ Programming: From Problem Analysis to Program…
C++ Programming: From Problem Analysis to Program…
Computer Science
ISBN:
9781337102087
Author:
D. S. Malik
Publisher:
Cengage Learning