博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
求栈中的最大值
阅读量:4974 次
发布时间:2019-06-12

本文共 977 字,大约阅读时间需要 3 分钟。

利用一个辅助的顺序表来

先定义栈和顺序表

typedef struct _Seqlist {    DataType array[MaxNum];    int len;}Seqlist,*PSeqlist;typedef struct _Stack {    DataType array[MaxNum];    int len;}Stack,*PStack;

入栈出栈时,都更新顺序表

int PushStack(PStack sta,DataType key,PSeqlist list){    if (sta->len > MaxNum)    {        printf("Out of Stack!\n");        return Empty;    }    else    {        sta->array[sta->len++] = key;        if ((list->len > 0) && key > list->array[list->len-1])        {            list->array[list->len++] = key;        }        else        {            list->array[list->len] = list->array[list->len-1];            list->len++;        }    }    return list->array[list->len-1];}int PopStack(PStack sta,PSeqlist list){    if (sta->len < 1)    {        printf("Lilk of Stack!\n");        return Empty;    }    else    {        int ret;        sta->array[--sta->len] = 0;        ret = list->array[--list->len-1];        return ret;     }}

 

转载于:https://www.cnblogs.com/dingsd/p/3334269.html

你可能感兴趣的文章
前端利器躬行记(2)——Babel
查看>>
前端利器躬行记(6)——Fiddler
查看>>
Intellij Idea新建web项目(转)
查看>>
用JAVA编写浏览器内核之实现javascript的document对象与内置方法
查看>>
centos iptables
查看>>
unity3d 移动与旋转 2
查看>>
寻找二叉查找树中比指定值小的所有节点中最大的那个节点
查看>>
如何设置输入框达到只读效果
查看>>
RT3070 USB WIFI 在连接socket编程过程中问题总结
查看>>
MIS外汇平台荣获“2013年全球最佳STP外汇交易商”
查看>>
LeetCode 题解之Add Digits
查看>>
hdu1502 , Regular Words, dp,高精度加法
查看>>
SpringBoot在idea中的热部署配置
查看>>
MyEclipse连接SQL Server 2008数据库的操作方法
查看>>
JS验证图片格式和大小并预览
查看>>
laravel5.2 移植到新服务器上除了“/”路由 ,其它路由对应的页面显示报404错误(Object not found!)———新装的LAMP没有加载Rewrite模块...
查看>>
编写高质量代码--改善python程序的建议(六)
查看>>
windows xp 中的administrator帐户不在用户登录内怎么解决?
查看>>
接口和抽象类有什么区别
查看>>
Codeforces Round #206 (Div. 2)
查看>>