#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 a void
function which just discards the top element on the stack, in order to get the value you want to use stack::top
.
The reason this is so is for exception safety reasons (what happens if the object returned throws an exception in its copy constructor?).
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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With