Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
76 changes: 76 additions & 0 deletions stack.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
\*Program to implement a stack using
two queue */



#include<stdio.h>

using namespace std;

class Stack
{
int q1, q2,x;
int curr_size;

public:
Stack()
{
curr_size = 0;
}

void push(int x)
{
curr_size++;
q2.push(x);

while (!q1.empty())
{
q2.push(q1.front());
q1.pop();
}

Int(q = q1);
q1 = q2;
q2 = q;
}

void pop(){

if (q1.empty())
return ;
q1.pop();
curr_size--;
}

int top()
{
if (q1.empty())
return -1;
return q1.front();
}

int size()
{
return curr_size;
}
};

int main()
{
Stack s;
s.push(1);
s.push(2);
s.push(3);

cout << "current size: " << s.size()
<< endl;
cout << s.top() << endl;
s.pop();
cout << s.top() << endl;
s.pop();
cout << s.top() << endl;

cout << "current size: " << s.size()
<< endl;
return 0;
}