49 lines
1017 B
C
Raw Normal View History

2024-08-05 01:10:12 +05:30
#include <stdio.h>
2024-08-07 17:08:15 +05:30
2024-08-05 01:10:12 +05:30
#define NUM_STACKS 3
2024-08-07 17:08:15 +05:30
#define MAX 100
int top[NUM_STACKS];
int stack[NUM_STACKS][MAX];
2024-08-05 01:10:12 +05:30
2024-08-07 17:08:15 +05:30
void push(int stack_index, int value) {
if (top[stack_index] == MAX - 1) {
printf("Stack is full\n");
return;
2024-08-05 01:10:12 +05:30
}
2024-08-07 17:08:15 +05:30
stack[stack_index][++top[stack_index]] = value;
2024-08-05 01:10:12 +05:30
}
2024-08-07 17:08:15 +05:30
int pop(int stack_index) {
if (top[stack_index] == -1) {
printf("Stack is empty\n");
2024-08-05 01:10:12 +05:30
return -1;
}
2024-08-07 17:08:15 +05:30
return stack[stack_index][top[stack_index]--];
2024-08-05 01:10:12 +05:30
}
int main() {
2024-08-07 17:08:15 +05:30
for (int i = 0; i < NUM_STACKS; i++) {
top[i] = -1;
}
for (int i = 0; i < NUM_STACKS; i++) {
printf("Enter elements for Stack %d:\n", i + 1);
for (int j = 0; j < 5; j++) {
int value;
scanf("%d", &value);
push(i, value);
}
}
for (int i = 0; i < NUM_STACKS; i++) {
printf("Stack %d: ", i + 1);
for (int j = 0; j <= top[i]; j++) {
printf("%d ", stack[i][j]);
}
printf("\n");
}
2024-08-05 01:10:12 +05:30
return 0;
}