栈
Posted 你在学什么
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了栈相关的知识,希望对你有一定的参考价值。
每日温度
class Solution
public int[] dailyTemperatures(int[] temperatures)
int n = temperatures.length;
int[] res = new int[n];
Deque<Integer> stack = new LinkedList<>();
for (int i = 0; i < n; ++i)
while (!stack.isEmpty() && temperatures[i] > temperatures[stack.peek()])
int temp = stack.pop();
res[temp] = i - temp;
stack.push(i);
return res;
顺序栈:创建&初始化入栈出栈计算栈中有效数据长度获取栈顶数据清空栈销毁栈
/*
顺序栈的实现:
初始化
入栈
出栈
计算栈的有效数据长度
获取栈顶数据
清空栈
销毁栈
*/
#include <stdio.h>
#include <stdlib.h>
#define ElemType int
typedef struct __stackInfo
{
ElemType *data;
unsigned int top;
unsigned int capacity;
} stackInfo;
/* 初始化 */
int initStack(stackInfo **ppS, unsigned int size)
{
if (NULL == ppS)
{
printf("ppNewStack point address is not exist
");
return -1;
}
stackInfo *pNewStack = (stackInfo *)malloc(sizeof(stackInfo));
if (NULL == pNewStack)
{
printf("ppNewStack malloc fail
");
return -1;
}
pNewStack->data = (ElemType *)malloc(sizeof(ElemType)*size);
if (NULL == pNewStack->data)
{
printf("ppNewStack databuf malloc fail
");
/* 前面几篇代码就少了这里,务必要小心,记个坑: 一旦直接推出,则泄漏内存pNewStack */
free(pNewStack);
return -1;
}
pNewStack->capacity = size;
pNewStack->top = 0;
*ppS = pNewStack;
return 0;
}
/* 入栈 */
int pushStack(stackInfo *pS, int val)
{
if (NULL == pS)
{
printf("pStack point NULL
");
return -1;
}
if (pS->capacity == pS->top)
{
printf("pStack full
");
return -1;
}
pS->data[pS->top] = val;
pS->top++;
return 0;
}
/* 出栈 */
int popStack(stackInfo *pS, int *val)
{
if ((NULL == pS) || (NULL == val))
{
printf("pStack point NULL or val point NULL
");
return -1;
}
if (pS->top <= 0)
{
printf("pStack empty
");
return -1;
}
pS->top--;
*val = pS->data[pS->top];
return 0;
}
/* 获取栈顶数据 */
int topStack(stackInfo *pS, int *val)
{
if ((NULL == pS) || (NULL == val))
{
printf("pStack point NULL or val point NULL
");
return -1;
}
if (0 >= pS->top)
{
printf("pStack empty
");
return -1;
}
*val = pS->data[pS->top - 1];
return 0;
}
/* 计算栈中有效数据长度 */
int lengthOfStack(stackInfo *pS, unsigned int *val)
{
if ((NULL == pS) || (NULL == val))
{
printf("pStack point NULL or val point NULL
");
return -1;
}
*val = pS->top;
return 0;
}
/* 清空栈 */
int emptyStack(stackInfo *pS)
{
if (NULL == pS)
{
printf("pStack point NULL
");
return -1;
}
while(pS->top)
{
/* 小技巧:如果赋值为0即0,如果赋值为FF,因16、32位平台的区别,鉴于可移植性考虑,赋值为0按位取反 */
pS->data[pS->top--] = ~0;
}
return 0;
}
/* 销毁栈 */
int destoryStack(stackInfo **ppS)
{
if (NULL == ppS)
{
printf("pStack point address is not exist
");
return -1;
}
if (NULL == *ppS)
{
printf("pStack point NULL
");
return -1;
}
emptyStack(*ppS);
/* 关注点:1、两块动态内存需释放 2、注意释放的先后顺序 */
free((*ppS)->data);
free(*ppS);
return 0;
}
/* 测试入口 */
int main(void)
{
stackInfo *pNewStack = NULL;
unsigned int length = 0;
int val = 0;
initStack(&pNewStack, 10);
lengthOfStack(pNewStack, &length);
printf("pNewStack valid length: %d
", length);
/* 创建10个元素的栈,入栈11次,检查软件的容错机制 */
for (int i=0; i<11; i++)
{
pushStack(pNewStack, i);
lengthOfStack(pNewStack, &length);
printf("pNewStack valid length: %d
", length);
}
/* 入栈10个数据,出栈11次,检查软件的容错机制 */
for (int i=0; i<11; i++)
{
topStack(pNewStack, &val);
printf("pNewStack top data: %d
", val);
popStack(pNewStack, &val);
printf("popStack data: %d
", val);
}
emptyStack(pNewStack);
lengthOfStack(pNewStack, &length);
printf("pNewStack valid length: %d
", length);
destoryStack(&pNewStack);
return 0;
}
以上是关于栈的主要内容,如果未能解决你的问题,请参考以下文章
虚拟内存[02] Linux 中的各种栈:进程栈 线程栈 内核栈 中断栈
Android UICanvas 画布 ① ( Canvas 状态栈 | Canvas 状态栈入栈与出栈 | 获取 Canvas 状态栈容量 | Canvas 状态栈原点数据 )