鱼C论坛

 找回密码
 立即注册
查看: 3458|回复: 3

[技术交流] 顺序栈(滞前)

[复制链接]
发表于 2017-12-23 14:58:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 qq1242009750 于 2017-12-23 15:09 编辑

                                                                            
顺序栈(滞前)

在23到28讲中鱼哥给我们讲了滞后的循序栈,现在我们来说说滞前栈。
什么是滞后、滞前栈呢? 其实就是入栈的时候栈顶指针的位置,如果入栈时栈顶指针指向前一个元素,那么就是滞前栈。
如果入栈后栈顶指针指向后一个元素,那么就是滞后栈。

结构的定义:
        struct Stack
        {
                int *base;
                int index;
                int StackSize;
        };

        class CStack
        {
        private:
                Stack stack;
        public:
                CStack();
                ~CStack();

                void Push(int e);
                void Pop(int *e);
        };
那滞前栈和滞后栈有什么不同呢? 其实都是一样的,只是出入栈的操作不同下面给出滞前栈代码
CStack::CStack()
{
        //初始化
        stack.index = -1;
        stack.base = new int[STACK_INIT_SIZE];
        stack.StackSize = STACK_INIT_SIZE;
}


CStack::~CStack()
{
        delete stack.base;
}


void CStack::Pop(int *e)
{
        if (&stack.base[stack.index] - stack.base + 1 == 0)
        {
                cout << "栈空!" << endl;
                return;
        }

        *e = stack.base[stack.index];
        --stack.index;
}


void CStack::Push(int e)
{
        if (&stack.base[stack.index] - stack.base + 1 == stack.StackSize)
        {
                //扩容
                int *tmp = stack.base;
                stack.base = new int[stack.StackSize + INCREMENT];
                memcpy(tmp, stack.base, stack.StackSize);
                stack.StackSize += INCREMENT;
                delete tmp;
        }

        stack.index++;
        stack.base[stack.index] = e;
}

可以看出滞前栈 入栈时先自增栈顶指针,后放入数值 ,而出时先去出数值后自减栈顶指针。那么栈元素的计算公式为: top - base + 1
滞后栈.png
滞前栈.png

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
小甲鱼 + 5 + 5 + 3 热爱鱼C^_^

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-12-23 15:03:26 | 显示全部楼层
支持并且鼓舞!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-12-23 15:06:34 | 显示全部楼层

谢谢 鱼哥的支持
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-8-9 22:11:18 | 显示全部楼层
涨知识了,很有用
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-24 08:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表