Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 9031799
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 16, 20262026-06-16T07:49:14+00:00 2026-06-16T07:49:14+00:00

So Im trying to make a double linked list that I can search for

  • 0

So Im trying to make a double linked list that I can search for the name and also search for people only below a certain age, but I dont know how to do that. So far Ive only got the one but Im having trouble.

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

     typedef string Elem;               // list element type
      class DNode {                 // doubly linked list node
      private:
        Elem elem;                  // node element value
        int age;
        DNode* prev;                // previous node in list
        DNode* next;                // next node in list
        friend class DLinkedList;           // allow DLinkedList access
      };

    class DLinkedList {             // doubly linked list
      public:
        DLinkedList();              // constructor
        ~DLinkedList();             // destructor
        bool empty() const;             // is list empty?
        const Elem& front() const;          // get front element
        const Elem& back() const;           // get back element
        void addFront(const Elem& name);        // add to front of list
        void addBack(const Elem& name);     // add to back of list
        void removeFront();             // remove from front
        void removeBack();              // remove from back
        void displayViaAge(string age);
        void displayViaName(const Elem& name);
        void removeName(const Elem& name);
      private:                  // local type definitions
        DNode* header;              // list sentinels
        DNode* trailer;
      protected:                    // local utilities
        void add(DNode* v, const Elem& name);       // insert new node before v
        void remove(DNode* v);          // remove node v
      };

      DLinkedList::DLinkedList() {          // constructor
        header = new DNode;             // create sentinels
        trailer = new DNode;
        header->next = trailer;         // have them point to each other
        trailer->prev = header;
      }

        DLinkedList::~DLinkedList() {           // destructor
        while (!empty()) removeFront();     // remove all but sentinels
        delete header;              // remove the sentinels
        delete trailer;
      }
                                    // insert new node before v
     void DLinkedList::add(DNode* v, const Elem& name) {
        DNode* u = new DNode;   
        u->elem = name;      // create a new node and set name
        u->next = v;                 // make v the successor of u
        u->prev = v->prev;           // set u's predecessor to v's current predecessor
        u->prev->next = u;           // make u the successor of v's predecessor
        v->prev = u;                 // finally make u the predecessor of v
    }
     /*
      void DLinkedList::removeName(const Elem& name) {
        DNode* u = new DNode;   u->elem = name;      // create a new node and set name
        u->next = v;                 // make v the successor of u
        u->prev = v->prev;           // set u's predecessor to v's current predecessor
        u->prev->next = u;           // make u the successor of v's predecessor
        v->prev = u;                 // finally make u the predecessor of v
    }
    */
      void DLinkedList::addFront(const Elem& name)  // add to front of list
        { add(header->next, name); }

      void DLinkedList::addBack(const Elem& name)   // add to back of list
        { add(trailer, name); }

       void DLinkedList::remove(DNode* v) {     // remove node v
        DNode* u = v->prev;             // predecessor
        DNode* w = v->next;             // successor
        u->next = w;                // unlink v from list
        w->prev = u;
        delete v;
      }

      void DLinkedList::removeFront()       // remove from font
        { remove(header->next); }

      void DLinkedList::removeBack()        // remove from back
        { remove(trailer->prev); }


         bool DLinkedList::empty() const        // is list empty?
        { return (header->next == trailer); }

      const Elem& DLinkedList::front() const    // get front element
        { return header->next->elem; }

      const Elem& DLinkedList::back() const     // get back element
        { return trailer->prev->elem; }

  void DLinkedList::displayViaAge(string age) {                     //Displays person via age
      //int check = 0;
      DNode*temp = header;

       while(temp!=trailer)
       {
        //  age = str.find(temp->elem);

        //   if(check == 1){
              cout << temp->elem <<endl;
              temp = temp -> next;
          // }
       }

       cout << temp->elem<<endl;
  }
       void DLinkedList::displayViaName(const Elem& name) {                     //Displays person via age
                  int check = 0;
          DNode*temp = header;

           while(temp!=trailer)
           {

               if(temp->elem == name){
                  cout << "Yes that Person is in out system" << endl;
                  check = 1;
               }
               temp = temp -> next;
           }

           if(temp->elem == name){
                  cout << "Yes that Person is in out system" << endl;
                  check = 1;
           }
           if(check == 0){ cout << "Sorry that person is not in our system" << endl;}
           check = 0;
      }

      class Person {
      public: 
        void print();
        string getName();
        int getAge();
      private:
          string name;
          int age;
      };

    int main(){
        char input = 'z';
        string entry;
        int age;
        DLinkedList person;

        person.addFront("Takkun Bradly 19");
        person.addFront("Devindra Ardnived 18");
        person.addFront("SeboY Wang 20");
        person.addFront("DoubleX Slash 31");
        person.addFront("Uncle Jelly 17");
        person.addFront("test 12");

        cout << "What would you like to do?" << endl;
        cout << "Enter 'A' to: Add a new person" << endl;
        cout << "Enter 'B' to: Remove a person" << endl;
        cout << "Enter 'C' to: Search for people via age" << endl;
        cout << "Enter 'D' to: Search for people via name" << endl;
        cout << "Enter 'E' to: Average all the total ages" << endl;
        cout << "Enter 'F' to: Quit" << endl;

    while(input != 'f') {

        cin >> input;
        cout << endl;

            while ((input != 'a')&&(input != 'b')&&(input != 'c')&&(input != 'd')&&(input != 'e')&&(input != 'f')) {

                cout << "Please enter a valid selection" << endl;           
                cin >> input;
            }

            if ((input == 'a')){
                cout << "Please enter their name and age: ";
                cin.ignore();
                getline(cin, entry);
                person.addFront(entry);

            }

            if ((input == 'b')){
                cout << "Who would you like to remove: ";
                cin.ignore();
                getline(cin, entry);
                person.removeFront();
            }

            if ((input == 'c')){
                cout << "What is the age of the person you are looking for?: ";
                cin.ignore();
                getline(cin, entry);
                person.displayViaAge(entry);
            }

            if ((input == 'd')){
                cout << "What is the name of the person you are looking for?: ";
                cin.ignore();
                getline(cin, entry);
                person.displayViaName(entry);
            }

            if ((input == 'e')){
                cout << "The total average of ages are: " << endl;
            }

            cout << endl;
        }
    }
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-16T07:49:16+00:00Added an answer on June 16, 2026 at 7:49 am

    You’ve taken several things you don’t know how to do, and welded them together into a problem you don’t know how to solve.

    You seem to assume that a name has two parts. Fine:

    if ((input == 'a')){
      cout << "Please enter their name and age: ";
      cin.ignore();
      cin >> firstName >> secondName >> age;
      ...
    }
    

    Then if you really want to store the name as a single string,

    name = firstName + " " + secondName;
    

    Now to create a new member of the list:

    person.addFront(name, age);
    

    This calls:

    void DLinkedList::add(DNode* v, const Elem& name, int age)
    

    The underlying problem here is that you knew you should handle name and age as separate variables, but you didn’t know how, so instead of finding out how you wrote a kludge, something that you did know how to do. And pretty soon you were trapped. Learn to listen to that little voice.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm trying to make an implementation of a double linked list which connects to
I'm trying to make a simple console-based program that can solve quadratic equations. I
I created a double linked list class, and am trying to use it with
I'm trying to make a Stack using an underlying linked list structure. Maybe I'm
I wrote the following code when trying to make a doubly-linked list with an
I am trying to make a tree template that can have any number of
I'm trying make an entity with doctrine that has three associations with other entities
Trying to make this jQuery filter that uses .find case-insensitive. For example, when the
I am trying to make a sequence of code that calculates the volume of
I am trying too delete a node in a doubly linked list, by an

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.