鱼C论坛

 找回密码
 立即注册
查看: 3471|回复: 11

c语言实现栈的基本操作

[复制链接]
发表于 2014-11-9 19:00:37 | 显示全部楼层 |阅读模式

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

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

x
C语言如何实现栈的基本操作、求源代码。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-11-10 21:35:44 | 显示全部楼层
翻书吧,书上都有
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-11-14 22:30:11 | 显示全部楼层
好好学习,天天向上
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-11-21 14:41:25 | 显示全部楼层
这个应该很多的。栈的基本操作的东西网上比较多。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-12-10 09:17:31 | 显示全部楼层
关注
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-12-14 22:33:21 | 显示全部楼层
看小甲鱼的视频  有讲的 上机打出的代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-12-15 09:17:39 | 显示全部楼层
typedef struct sqStack
{
    ElemType *top;
    ElemType *base;
    int initSize;
}sqStack;
typedef struct sqStack *LinkStack;

//初始化
void InitStack(sqStack *s)
{
    s->base = (LinkStack)malloc(Stack_Init_Size * sizeof(ElemType));
    if(!s->base)
    {
        printf("存储空间分配失败······\n");
        return;
    }
    s->top = s->base;
    s->initSize = Stack_Init_Size;
}
//进栈
void Push(sqStack *s,ElemType *e)
{
    if(s->top - s->base >= s->initSize - 1)
    {
        s->base = (LinkStack)realloc(s->base,(s->initSize + Increase_Size) * sizeof(ElemType));
        //第一个s->base是增加后的存储空间块的地址,第二个是增加空间之前的存储空间块地址,后面是增加过的存储空间块的大小
        if(!s->base)
        {
            printf("增加存储空间失败······\n");
            return;
        }
        s->initSize = Increase_Size + Stack_Init_Size;
    }
    *(s->top) = *e;
    (s->top)++;
}
//出栈
void Pop(sqStack *s,ElemType *e)
{
    if(s->top == s->base)
    {
        printf("栈已空,无法进行出栈操作······\n");
        return;
    }
    s->top--;
    *e = *s->top;
}
//求栈的长度
int StackLen(sqStack s)
{
    return (s.top - s.base);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-12-15 09:18:37 | 显示全部楼层
http://www.cnblogs.com/devinblog/
最近在博客上也写了一点程序,你可一看看,希望对你有帮助
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-12-15 22:41:26 | 显示全部楼层
小甲鱼有视频的  自己去看下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-12-29 19:53:26 | 显示全部楼层
mark
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-12-31 10:24:46 | 显示全部楼层
mark
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-1-8 20:33:21 | 显示全部楼层
//2014.10.02        顺序栈的实现方式
#include<iostream>
#include<math.h>
#include"assert.h"
using namespace std;

#define INCREMENT_SIZE 2
typedef struct STACK
{
        int stacksize;
        int* pstop;                        //栈顶指针p表示指针s表示栈 
        int* psbottom;
}STACK;

void init_stack(STACK& s)
{
        
        s.stacksize = INCREMENT_SIZE;
        //注意加1的原因:s.psbottom不存放数据本身要占据一个字节的空间
        s.pstop = s.psbottom =(int*)malloc(sizeof(int)*(s.stacksize+1));
        if(NULL ==         s.pstop)
        {
                cout<<"为栈分配存储空间失败";
                return;
        }
        
}



bool push(STACK& s,int val)
{
        
        int k = s.pstop-s.psbottom;
        if((s.pstop-s.psbottom)>=s.stacksize)
        {
                //注意加1的原因:s.psbottom不存放数据本身要占据一个字节的空间
                s.psbottom = (int*)realloc(s.psbottom ,sizeof(int)*(s.stacksize+INCREMENT_SIZE+1));
                if(NULL == s.psbottom)
                {
                        cout<<"栈已满,为将要压栈的元素分配内存失败"<<endl;
                        return false;
                }
                s.pstop = s.psbottom+s.stacksize;
                s.stacksize+=INCREMENT_SIZE;
        }
                s.pstop++;
                *s.pstop = val;
        
                return true;
}

bool pop(STACK& s,int& val)
{
        if(s.psbottom == s.pstop)
        {
                cout<<"栈为空出栈失败"<<endl;
                return false;
        }

        val = *s.pstop--;
        return true;
}
void dis_stack(STACK& s)
{
        if(s.pstop == s.psbottom)
        {
                cout<<"栈为空"<<endl;
                return ;
        }
        
        int* p = s.pstop ;
        while(p != s.psbottom)
        {
                cout<<*p<<endl;
                p--;
        }
}


bool get_top(STACK&s, int& val)
{
        if(s.psbottom == s.pstop)
        {
                cout<<"栈为空"<<endl;
                return false;
        }

        val = *s.pstop;
        return true;
}

STACK stack;
int main(void)
{
        init_stack(stack);
        push(stack,23);
        push(stack,78);
        push(stack,26);
         push(stack,90);
         push(stack,45);        
        push(stack,45);
        push(stack,78);
         push(stack,123);        
        dis_stack(stack);
        int val = 0;
        cout<<endl;
        pop(stack,val);
        cout<<val<<endl;
        cout<<endl;
        pop(stack,val);
        cout<<val<<endl;
        cout<<endl;
        dis_stack(stack);

        int top_val;
        get_top(stack,top_val);
        cout<<endl;
        cout<<top_val<<endl;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 07:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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