two problems in stack building program
The following program successfully builds up a stack , but the 2 operations pop and stack top are giving exception and wrong result respectively. Here is the program :
// Working with stack using Array
/*
 * @author Suhail Gupta
 *
 */
#include <iostream>
using namespace std;
char choice;
int *ptrToArray; // this will be a pointer to the array alias stack that we'll make
int stackSize;
int currentStackSize = 0;
int *firstElement = NULL; // this pointer stores the address of the first element in the stack. It initially points to NULL
void push();
void pop();
void stackTop();
int main() {
cout << "Enter the size of stack : ";
cin >> stackSize;
ptrToArray = new int[stackSize];
do {
     push();
    cout << "Push elements ? y/n ";
    cin >> choice;
} while( choice == 'y');
cout << endl << "pop elements ? y/n ";
cin >> choice;
if( choice == 'y') {
    pop();
}
cout << endl << "know the stack top ? y/n ";
cin >> choice;
if( choice == 'y') {
    stackTop();
}
 }
void push() {
if( currentStackSize == stackSize) {        // check before pushing if the stack is full
    cout << endl << "Stack-Overflow !";
} else {
    int numberToPush;
    cout << endl << "Enter the number to be pushed : ";
    cin >> numberToPush;
    firstElement = &numberToPush; // Store the address of t开发者_运维问答he Last number inserted.This is the address of the first element in the stack
    ptrToArray[currentStackSize] = numberToPush;
    cout << "The element you just inserted : " << ptrToArray[currentStackSize] << endl;
    currentStackSize++;     
 }    
}
void pop() {
if( stackSize == 0 ) {
    cout << "Stack Underflow !";
} else {
    delete firstElement; // delete the memory allocated to the first element
    firstElement = &ptrToArray[currentStackSize-1];
    currentStackSize--;
 }
}
void stackTop() {
if( firstElement == NULL) {
    cout << endl << "Stack Underflow !" << endl;
} else {
    cout << "The first element in the stack is : " << *firstElement;
  }
}
The pushing operation works fine.But if i call the pop function the following message is displayed :

Second question :
Now just comment the statement where pop function gets called . The result that i get when trying to know the first element on the stack by calling the function stackTop() is The first element in the stack is : -858993460 . This is some garbage number that i didn't enter while making up the stack. Why the statement *firstElement gives the wrong result then ?
int *firstElement = NULL; // Global pointer variable
void push() {
 // ...    
    else {
        // ..
        int numberToPush;  // Resides on stack.
        // ....
        firstElement = &numberToPush; 
        // ...
    } // numberToPush cease to exist from this point.
}
numberToPush is a local variable and have a blocked scope to else part and you are taking the reference of it.This is resulting you the garbage.
Edit: You need to understand that storage duration of global variables are different to that of local. Just taking the reference of local to a global variable doesn't increase the life time of a local variable. As soon as it's scope finishes, the variable ceases to exist.
You can't call delete on individual array elements. One new[] must be matched by precisely one delete[].
firstElement is pointing to a variable on the stack: numberToPush. When numberToPush goes out of context, the firstElement pointer becomes invalid. Which is why your pointer crashes when delete is called
easy...
in your push you did:
firstElement = &numberToPush; 
which make firstElement to get the address of the local variable which will be delete as the function quit. change it to:
firstElement = ptrToArray[currentStackSize];
AND you can't delete a single var in an array.
You should delete the entire array in the end of Main()  
Just remove the VAR firstElement - it's useless.
And do that:  
void push() {  
    if( currentStackSize == stackSize) {        // check before pushing if the stack is full
        cout << endl << "Stack-Overflow !";  
    } else {
        int numberToPush;  
        cout << endl << "Enter the number to be pushed : ";  
        cin >> numberToPush;  
        ptrToArray[currentStackSize] = numberToPush;  
        cout << "The element you just inserted : " << ptrToArray[currentStackSize] << endl;  
        currentStackSize++;      
    }      
}  
void pop() { 
    if( stackSize == 0 ) { 
        cout << "Stack Underflow !";  
    } else {  
        currentStackSize--;  
    }  
}  
void stackTop() {  
    cout << "The first element in the stack is : " << ptrToArray[currentStackSize];  
}  
 
         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论