logo CodeStepByStep logo


Language/Type: C++ Stack Queue collections
Related Links:
Author: Marty Stepp (on 2016/06/16)

Write a function named flipHalf that reverses the order of half of the elements of a Queue of integers, passed by reference as a parameter to your function. Your function should reverse the order of all the elements in odd-numbered positions (position 1, 3, 5, etc.) assuming that the first value in the queue has position 0. For example, if the queue originally stores this sequence of numbers when the function is called:

index: 0  1  2  3  4  5   6   7
front {1, 8, 7, 2, 9, 18, 12, 0} back

Then it should store the following values after the function finishes executing:

index: 0  1  2  3   4  5  6   7
front {1, 0, 7, 18, 9, 2, 12, 8} back

Notice that numbers in even positions (positions 0, 2, 4, 6) have not moved. That sub-sequence of numbers is still: (1, 7, 9, 12). But notice that the numbers in odd positions (positions 1, 3, 5, 7) are now in reverse order relative to the original. In other words, the original sub-sequence: (8, 2, 18, 0) - has become: (0, 18, 2, 8).

Constraints: You may use a single stack as auxiliary storage.

Type your solution here:

This is a function problem. Write a C++ function as described. Do not write a complete program; just the function(s) above.

You must log in before you can solve this problem.

Log In

If you do not understand how to solve a problem or why your solution doesn't work, please contact your TA or instructor.
If something seems wrong with the site (errors, slow performance, incorrect problems/tests, etc.), please

Is there a problem? Contact a site administrator.

© Marty Stepp, all rights reserved.