数组实现堆栈

#include <stdio.h>
#include <stdlib.h>

void insert(int);
void dele();
void display();


int s[20], item, i, n = 10;
int top = -1;

int main(void)
{
    while(1){
        printf("Array implementation of a stack\n");
        printf("1, Insertion \n");
        printf("2, Deletion \n");
        printf("3, Display \n");
        printf("Enter your choice [1..4]");
        scanf("%d", &i);
        
        switch(i){
        case 1:
            printf("Insertion \n");
            printf("Enter item\n");
            scanf("%d", &item);
            insert(item);
            break;
        case 2:
            printf("Delletion\n");
            dele();
            break;
        case 3:
            display();
            break;
        case 4:
            exit (1);
            break;
        default:
            exit(-1);
            
            
            
        }
        
        
    }
    
}

void insert(int item)
{
    if (top > n)
        printf("Stack is full");
    top = top + 1;
    s[top] = item;

    return ;
    
}

void dele()
{
    if (top < 0){
        printf("stack is empty\n");
        return ;
        
    }
    item = s[top--];
    printf("Deleted item is %d", item);
    printf("\n");
    
}

void display()
{
    int i = 0;
    printf("Content of this stack is :");
    while (i <= top){
        printf("%d ", s[i]);
        i++;
        
    }
    printf("\n");
    
    return ;
    
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值