#include <stack>
using namespace std;
int main() {
stack<int> s;
int i;
for (i = 0; i <= 10; i++) {
s.push(i);
}
for (i = 0; i <= 10; i++) {
printf("%d", s.pop());
}
}
Whats wrong with the code above?
Error:
In function
int main()
: aggregate value used where an integer was expected
stack::pop
is avoid
function which just discards the top element on the stack, in order to get the value you want to usestack::top
.The reason this is so is for exception safety reasons (what happens if the object returned throws an exception in its copy constructor?).
You're treating pop() which is an operation to print to standard output. pop() just removes the topmost element from the stack. The most confusing thing however is your debug output.
I compiled your code fragment with the standard GNU C++ compiler which gave me:
Minor nitpick, your for loop is actually encoding 11 items and not 10 like you make think from a brief look at the loop count. Consider using < 11 if you mean 11 elements to add.