Elements of a list begin numbering

Assignment Help C/C++ Programming
Reference no: EM131204055

For this program you will add and test 2 new member functions to the IntSLList class posted on the website.

The two member functions are:

insertByPosn(int el, intpos)

Assuming that the positions of elements of a list begin numbering at 1 and continue to the end of the list, you will insert a new node with info value el at position pos.  pos will become the position of the new node in the modified list.  For example, if pos = 1, insert the new node at the head of the list.  If pos = 2, for example, insert the new node BEFORE the node currently at position 2. If the list is empty prior to insertion, insert the new node in the list and adjust head and tail pointers.  If pos is too large, don't do anything. If pos is 0 or negative, don't do anything.

deleteByPosn(intpos)

Assume position of elements are defined as above. If pos is zero or negative, do nothing.  If the list is empty prior to the request to delete a node, do nothing. If pos is too large, do nothing.

To aid in verifying results, you should use the following modified version of printAll.  This requires:  include <string>

voidIntSLList::printAll(stringlocn) const {

cout<<"Contents of the list "<<locn<<endl;

for (IntSLLNode *tmp = head; tmp != 0; tmp = tmp->next)

cout<<tmp->info <<" ";

if (head != 0)

       cout<<"Head is: "<< head->info <<" Tail is: "<< tail->info <<endl<<endl;

}

For extra credit, you can also create the following:

reverseList()

Traverse the existing list beginning at the head and create a new (reversed) list with head newhead and tail newtail.  Put new nodes in the new list by putting the new nodes at the head of the new list each time. Do not call any other member functions during this process. If the list to be reversed is empty, make sure that you account for this case. After the new (reversed) list is created, delete the old list using its destructor.

The test program to be used is:

int main()

{

       IntSLListsingly_linked_list = IntSLList();

       singly_linked_list.addToHead(9);

singly_linked_list.addToHead(7);

       singly_linked_list.addToHead(6);

       singly_linked_list.printAll("at creation:");

       singly_linked_list.insertByPosn(8, 2);

       singly_linked_list.printAll("after insertion of 8 at position 2:");

       singly_linked_list.insertByPosn(10, 4);

       singly_linked_list.printAll("after insertion of 10 at position 4:");

       singly_linked_list.insertByPosn(12, 6);

       singly_linked_list.printAll("after insertion of 12 at position 6:");

       singly_linked_list.insertByPosn(14, 8);

       singly_linked_list.printAll("after attempted insertion of 14 at position 8:");

       singly_linked_list.insertByPosn(5, 1);

       singly_linked_list.printAll("after insertion of 5 at position 1:");

       singly_linked_list.insertByPosn(4, 0);

       singly_linked_list.printAll("after attempted insertion of 4 at position 0:");

       singly_linked_list.removeByPosn(2);

       singly_linked_list.printAll("after deletion of 6 at position 2:");

       singly_linked_list.removeByPosn(6);

       singly_linked_list.printAll("after deletion of 12 at position 6:");

       singly_linked_list.removeByPosn(10);

       singly_linked_list.printAll("after attempted deletion at position 10:");

       // insert test for optional list reversal here

       return (0);

}

The correct output from running the test program is:

Contents of the list at creation:

6 7 9 Head is: 6 Tail is: 9

Contents of the list after insertion of 8 at position 2:

6 8 7 9 Head is: 6 Tail is: 9

Contents of the list after insertion of 10 at position 4:

6 8 7 10 9 Head is: 6 Tail is: 9

Contents of the list after insertion of 12 at position 6:

6 8 7 10 9 12 Head is: 6 Tail is: 12

Contents of the list after attempted insertion of 14 at position 8:

6 8 7 10 9 12 Head is: 6 Tail is: 12

Contents of the list after insertion of 5 at position 1:

5 6 8 7 10 9 12 Head is: 5 Tail is: 12

Contents of the list after attempted insertion of 4 at position 0:

5 6 8 7 10 9 12 Head is: 5 Tail is: 12

Contents of the list after deletion of 6 at position 2:

5 8 7 10 9 12 Head is: 5 Tail is: 12

Contents of the list after deletion of 12 at position 6:

5 8 7 10 9 Head is: 5 Tail is: 9

Contents of the list after attempted deletion at position 10:

5 8 7 10 9 Head is: 5 Tail is: 9

Reference no: EM131204055

Questions Cloud

Change have a good or bad consequences : Some members of the Tea Party movement want to repeal the seventeenth Amendment, Which provides for electing U.S. senators popular vote. If the amendment were repealed, state legislatures would choose each state's senators. Advocates of repeal argue ..
Concerning the national defense authorization act is true : Which one of the following statements concerning the national defense authorization act is true?
Homework on ricardian model : Homework on Ricardian Model. Suppose in the United States, one worker can produce 10 tons of steel per day or 20 tons of chemicals per day. In the United Kingdom, one worker can produce 5 tons of steel per day or 15 tons of chemicals per day.  Show t..
Supply and demand model applies to the market in italics : Assuming the classic supply and demand model applies to the market in italics ,graphically illustrate how the following events would impact the market. Be sure to note the specific DETERMINANT that aided you in your graphical analysis. Annie Vance Wi..
Elements of a list begin numbering : For this program you will add and test 2 new member functions to the IntSLList class posted on the website.Assuming that the positions of elements of a list begin numbering at 1 and continue to the end of the list, you will insert a new node with i..
What is the major advantage of using the technique : What is the major advantage of using the technique of avoidance in a risk management program? Is it possible or practical for a firm to avoid all potential losses? Explain your answer.
Using substitution theorem draw three equivalent branches : Using the substitution theorem, draw three equivalent branches for the branch a-b of the network of given figure b.
What is the maximum property tax levy that would be allowed : What was the property tax levy in 2015? What is the maximum property tax levy that would be allowed in 2016? What is the market value of taxable property in 2016?
Develop an intervention plan : Discuss which population is most affected by this Topic Area and why - Describe what impact this Topic Area has on the health of individuals.

Reviews

Write a Review

C/C++ Programming Questions & Answers

  Implementation of a user-defined class

For this assignment you will complete the implementation of a user-defined C++ class to represent arithmetic expressions. The interface of the class is shown below

  Program that displays the ball at a random

Write a C++ program that displays the ball at a random location and then makes the ball move down to the bottom of the screen. When the ball reaches the bottom of the screen, it should start these actions over again, appear-ing at another random l..

  Find largest sum will return the column with the largest sum

Find Largest Sum will return the column with the largest sum. If two or more columns, share the largest sum, print out only one column. Find Smallest Value will return the smallest value within the given 2d array.

  What is the output of the loop as it is written

Correct the syntax of the loop so that the logic of the corrected loop corresponds to the formatting of the original loop. What is the output of the corrected loop?

  Write print out average of numbers

Im having trouble writing a program that uses functions. the program uses data from a data file ("numbers.dat") and is to be written to an output file ("output2.dat").

  Inserts a node with info value x

Complete the code for a function that inserts a node with info      value x before, and a node with info value zafter,each node with      info value y in a linked list with first node pointer p.

  Windows application that function like a banking account

Create a Windows application that function like a banking account register. Separate the business logic from the presentation layer. The graphical user interface should allow user to input the account name, number, and balance.

  A sample of helium gas occupies 945ml at 605 mmhg

A sample of helium gas occupies 945mL at 605 mmHg. For a gas sample at a constant temperature, determine the volume of helium at 745 mmHg?

  Explain how to represent a lagged fibonacci generator

Explain how to represent a lagged Fibonacci generator using list abstract data types. What representation would be the most appropriate?

  Write a function named read_line

supposes you have a directory whose name is stored in 'specs.file_dir' which contains a file whose name is stored in 'specs.file_name'.

  Write a program to output accumulated values

Write a program to output accumulated values for each month, given a set amount saved each month, until the accumulated amount reaches a set goal amount.

  Initial size of the culture

The count in a bacteria culture was 600 after 10 minutes and 2000 after 40 minutes. Assuming the count grows exponentially, What was the initial size of the culture?

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd