Data structures and algorithms in C++
Data structures and algorithms in C++
2nd Edition
ISBN: 9780470460443
Author: Goodrich
Publisher: WILEY
Expert Solution & Answer
Book Icon
Chapter 3, Problem 8R

Explanation of Solution

Program code:

//include the required header files

#include<iostream>

#include<cstdio>

#include<cstdlib>

/* Node Declaration*/

using namespace std;

//create a structure

struct node

{

//structure members

int info;

struct node *next;

struct node *prev;

}*start;

/*Class Declaration */

class double_llist

{

//public access modifier

public:

//declare the member functions

void create_list(int value);

void add_begin(int value);

void add_after(int value, int position);

void delete_element(int value);

void search_element(int value);

void display_dlist();

void count();

void reverse();

//define a method

double_llist()

{

//set the value of start

start = NULL;

}

};

/* Main*/

int main()

{

//declare the required variables

int choice, element, position;

double_llist dl;

//iterate a while loop

while (1)

{

//display the choices

cout<<endl<<"----------------------------"<<endl;

cout<<endl<<"Operations on Doubly linked list"<<endl;

cout<<endl<<"----------------------------"<<endl;      

cout<<"1.Create Node"<<endl;

cout<<"2.Add at begining"<<endl;

cout<<"3.Add after position"<<endl;

cout<<"4.Delete"<<endl;

cout<<"5.Display"<<endl;

cout<<"6.Count"<<endl;

cout<<"7.Reverse"<<endl;

cout<<"8.Quit"<<endl;

//prompt the user to enter the choice

cout<<"Enter your choice : ";

cin>>choice;

//switch cases

switch ( choice )

{

//case 1

case 1:

//prompt the user to enter the element

cout<<"Enter the element: ";

//scan for the value

cin>>element;

//call the method create_list(element)

dl.create_list(element);

//new line

cout<<endl;

//break fron the case

break;

case 2:

//prompt the user to enter the element

cout<<"Enter the element: ";

//scan for the value

cin>>element;

//call the method add_begin(element)

dl.add_begin(element);

//new line

cout<<endl;

//break fron the case

break;

case 3:

//prompt the user to enter the element

cout<<"Enter the element: ";

//scan for the value

cin>>element;

//prompt the user to enter the position

cout<<"Insert Element after postion: ";

cin>>position;

//call the method add_after(element)

dl.add_after(element, position);

//new line

cout<<endl;

//break fron the case

break;

case 4:

//if the condition is true

if (start == NULL)

{

//print the statement

cout<<"List empty,nothing to delete"<<endl;

//break fron the condition

break;

}

//prompt the user to enter the element

cout<<"Enter the element for deletion: ";

//scan for the value

cin>>element;

//call the method delete_element(element)

dl.delete_element(element);

//new line

cout<<endl;

//break fron the case

break;

case 5:

//call the method display_dlist(element)

dl.display_dlist();

//new line

cout<<endl;

//break fron the case

break;

case 6:

//call the method count(element)

dl.count();

//break fron the case

break;

case 7:

//if the condition is true

if (start == NULL)

{

//print the statement

cout<<"List empty,nothing to reverse"<<endl;

//break fron the condititon

break;

}

//call the method reverse(element)

dl.reverse();

//new line

cout<<endl;

//break fron the case

break;

case 8:

//exit from while loop

exit(1);

default:

//print the statement

cout<<"Wrong choice"<<endl;

}

}

//return zero

    return 0;

}

/* Create Double Link List*/

void double_llist::create_list(int value)

{

//create struct vaiable

struct node *s, *temp;

//set the value of temp

temp = new(struct node);

//insert the value

temp->info = value;

//set next as Null

temp->next = NULL;

//if the condition is true

if (start == NULL)

{

//set prev equal to Null

temp->prev = NULL;

//set start equal to temp

start = temp;

}

else

{

    //set s equal to start

s = start;

//iterate a while loop

while (s->next != NULL)

//assign the value

s = s->next;

s->next = temp;

temp->prev = s;

}

}

/* Insertion at the beginning */

void double_llist::add_begin(int value)

{

//if the condition is true

if (start == NULL)

{

//print the statement

cout<<"First Create the list."<<endl;

return;

}

//inserting the element

struct node *temp;

temp = new(struct node);

temp->prev = NULL;

temp->info = value;

temp->next = start;

start->prev = temp;

start = temp;

cout<<"Element Inserted"<<endl;

}

/* Insertion of element at a particular position*/

void double_llist::add_after(int value, int pos)

{

//if the condition is true

if (start == NULL)

{

//print the statement

cout<<"First Create the list."<<endl;

//return

return;

}

//create struct variables

struct node *tmp, *q;

//create the required variables

int i;

q = start;

//iterate a for loop

for (i = 0;i < pos - 1;i++)

{

//set the value of q

q = q->next;

//if the value of q equal to null

if (q == NULL)

{

//print the statement

cout<<"There are less than ";

cout<<pos<<" elements...

Blurred answer
Students have asked these similar questions
What are the major threats of using the internet? How do you use it? How do children use it? How canwe secure it? Provide four references with your answer. Two of the refernces can be from an article and the other two from websites.
Assume that a string of name & surname is saved in S. The alphabetical characters in S can be in lowercase and/or uppercase letters. Name and surname are assumed to be separated by a space character and the string ends with a full stop "." character. Write an assembly language program that will copy the name to NAME in lowercase and the surname to SNAME in uppercase letters. Assume that name and/or surname cannot exceed 20 characters. The program should be general and work with every possible string with name & surname. However, you can consider the data segment definition given below in your program. .DATA S DB 'Mahmoud Obaid." NAME DB 20 DUP(?) SNAME DB 20 DUP(?) Hint: Uppercase characters are ordered between 'A' (41H) and 'Z' (5AH) and lowercase characters are ordered between 'a' (61H) and 'z' (7AH) in the in the ASCII Code table. For lowercase letters, bit 5 (d5) of the ASCII code is 1 where for uppercase letters it is 0. For example, Letter 'h' Binary ASCII 01101000 68H 'H'…
What did you find most interesting or surprising about the scientist Lavoiser?
Knowledge Booster
Background pattern image
Similar questions
SEE MORE QUESTIONS
Recommended textbooks for you
Text book image
Database System Concepts
Computer Science
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:McGraw-Hill Education
Text book image
Starting Out with Python (4th Edition)
Computer Science
ISBN:9780134444321
Author:Tony Gaddis
Publisher:PEARSON
Text book image
Digital Fundamentals (11th Edition)
Computer Science
ISBN:9780132737968
Author:Thomas L. Floyd
Publisher:PEARSON
Text book image
C How to Program (8th Edition)
Computer Science
ISBN:9780133976892
Author:Paul J. Deitel, Harvey Deitel
Publisher:PEARSON
Text book image
Database Systems: Design, Implementation, & Manag...
Computer Science
ISBN:9781337627900
Author:Carlos Coronel, Steven Morris
Publisher:Cengage Learning
Text book image
Programmable Logic Controllers
Computer Science
ISBN:9780073373843
Author:Frank D. Petruzella
Publisher:McGraw-Hill Education