• C语言栈的实现


    static.h

    #define STATIC_INIT_SIZE 100
    #define STATICINCREMENT 10
    #define ERROR 0
    #define OK 1
    typedef struct {

    int *base;//定义栈底
    int *top;//定义栈顶元素
    int staticsize;

    }SqStatic;

    typedef int Status;

    //初始化一个空栈
    Status InitStatic(SqStatic *S);

    //销毁栈
    Status DestroyStatic(SqStatic *S);

    //清空栈
    Status ClearStatic(SqStatic *S);

    //判断栈是否为空
    Status StaticEmpty(SqStatic S);

    //获取栈的长度
    int StaticLength(SqStatic S);

    //获取栈顶元素的值
    Status GetTop(SqStatic S, int *e);

    //向栈中加入元素
    Status Push(SqStatic *S,int e);

    //删除栈顶元素并返回元素值
    Status Pop(SqStatic *S, int *e);

    void conversion(SqStatic *S)

    StaticRealize.c

    #include "stdlib.h"
    #include "stdio.h"
    #include "static.h"


    Status InitStatic(SqStatic *S) {

    //设置初始栈的大小
    S->base = (int *)malloc(sizeof(int)*STATIC_INIT_SIZE);

    if (!S->base) {
    exit(0);
    }
    S->top = S->base;//空栈 s->top=s->base
    *(S->top) = 0;//主要用来判断是否为空栈
    S->staticsize = STATIC_INIT_SIZE;//栈的初始长度为100

    return OK;
    }
    //获取栈顶元素的值
    Status GetTop(SqStatic S, int *e) {

    SqStatic q;
    q = S;
    //返回栈顶元素需要判断栈是否为空栈
    if (S.base == S.top) return ERROR;

    *e = *(q.top - 1);

    return OK;

    }

    //元素的进栈
    Status Push(SqStatic *S,int e) {

    if ((S->top-S->base)>=S->staticsize) {

    S->base = (int *)realloc(S->base,(STATICINCREMENT+STATIC_INIT_SIZE)*sizeof(int));
    }
    *(S->top) = e;

    S->top++;
    return OK;

    }


    Status Pop(SqStatic *S,int *e) {

    if (S->top == S->base)return ERROR;

    S->top--;
    *e = *(S->top);

    return OK;

    }

    Status StaticEmpty(SqStatic S) {
    if (*(S.top) == 0) {

    return OK;
    }
    return ERROR;
    }


    //返回栈中元素的个数
    int StaticLength(SqStatic S) {

    return S.top - S.base;
    }

    //十进制转换为二进制

    void conversion(SqStatic *S) {

    printf("请输入要转换的整数 ");
    int n;
    int e;
    scanf("%d",&n);
    while (n)
    {
    int c = n % 2;
    Push(S,c);
    n =n/2;

    }
    printf("输出转换后的二进制 ");

    while (!StaticEmpty(*S))
    {
    Pop(S,&e);

    printf("%d",e);

    }
    printf(" ");


    }

    StaticFunction.c

    #include "stdio.h"
    #include "stdlib.h"
    #include "static.h"
    //主函数
    void main() {

    //初始化一个空栈
    SqStatic S;

    int e,f;

    InitStatic(&S);
    // printf("判断栈是否为空栈%d ", StaticEmpty(S));

    Push(&S,1);
    GetTop(S, &e);
    printf("栈顶元素为%d ", e);

    Push(&S,2);
    GetTop(S, &e);
    printf("栈顶元素为%d ", e);

    Push(&S,3);
    GetTop(S, &e);
    printf("栈顶元素为%d ", e);

    Push(&S,4);
    GetTop(S, &e);
    printf("栈顶元素为%d ",e);

    Pop(&S, &f);

    printf("弹出的值为%d ",f);

    Pop(&S, &f);

    //10进制转换为二进制

    conversion(&S);

    printf("弹出的值为%d ", f);

    printf("判断栈是否为空栈%d ", StaticEmpty(S));

    printf("栈的长度为%d ",StaticLength(S));


    }

  • 相关阅读:
    微信小程序保存图片功能实现
    小程序清除缓存功能如何实现
    小程序自定义函数—数字千位转换
    小程序身份证号检测函数
    小程序 的 textarea 组件 层级问题如何解决
    Markdown 语法背一下咯
    跨域了解一下?
    sort命令的k选项大讨论【转】
    Shell脚本中实现切换用户并执行命令操作【转】
    Ansible Tower系列 四(使用tower执行一个命令)【转】
  • 原文地址:https://www.cnblogs.com/paulversion/p/7576079.html
Copyright © 2020-2023  润新知