带最小值操作的栈

描述
ENG
实现一个栈, 支持以下操作:
push(val) 将 val 压入栈
pop() 将栈顶元素弹出, 并返回这个弹出的元素
min() 返回栈中元素的最小值
要求 O(1) 开销.

输入: 
  push(1)
  min()
  push(2)
  min()
  push(3)
  min()
输出: 
  1
  1
  1

#include <stdio.h>
#include <stdlib.h>
struct linklist{
    int val;
    struct linklist *next;
};
struct linklist *head;

void push(int val)
{
    struct linklist *tmp = (struct linklist *)malloc(sizeof(struct linklist));

    tmp->val = val;
    tmp->next = head->next;

    head->next = tmp;

    if (head->val > val)
        head->val = val;
}

int min()
{
    return head->val;
}

int pop()
{
    struct linklist *ptr;
    int val;

    //stack is empty
    if (head->next == NULL)
        return -1;

    ptr = head->next;
    head->next = ptr->next;

    val = ptr->val;

    free(ptr);

    return val;
}

int main()
{
    head = (struct linklist *)malloc(sizeof(struct linklist));

    head->val = 0xFFFF;
    head->next = NULL;

    push(1);
    printf("%d\n", min());
    push(2);
    printf("%d\n", min());
    push(3);
    printf("%d\n", min());
    printf("%d, %d\n", pop(), min());
    printf("%d, %d\n", pop(), min());
    printf("%d, %d\n", pop(), min());
    free(head);
    return 0;
}
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mounter625

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值