当前位置: 首页 > news >正文

各大网站的域名是什么原因重庆seo排名

各大网站的域名是什么原因,重庆seo排名,淮南做网站,什么网站系统做的最好代码是参考的康建伟老师的: https://www.cnblogs.com/kangjianwei101/p/5221816.html,以及用copilot做了一些改进 下面主要记录一些问题(核心代码附在最后) 对有一些边界条件有疑惑,整理了一下 函数名if 条件判断条件含义InitStac…

代码是参考的康建伟老师的: https://www.cnblogs.com/kangjianwei101/p/5221816.html,以及用copilot做了一些改进

下面主要记录一些问题(核心代码附在最后)

  • 对有一些边界条件有疑惑,整理了一下

    函数名if 条件判断条件含义
    InitStackif (S == NULL)检查栈指针是否为空,避免对空指针进行操作
    InitStackif ((*S).base == NULL)检查分配内存是否成功,若不成功则退出程序
    DestroyStackif (S == NULL)检查栈指针是否为空,避免对空指针进行操作
    ClearStackif (S == NULL ||(*S).base == NULL)检查栈指针是否为空,以及栈是否已经初始化
    StackEmptyif (S.top == S.base)检查栈顶指针是否与栈底指针相等,以判断栈是否为空
    StackLengthif (S.base == NULL)检查栈是否已经初始化
    GetTopif (S.base == NULL ||( S.top == S.base)检查栈是否已经初始化,以及栈是否为空
    Pushif (S == NULL ||( (*S).base == NULL)检查栈指针是否为空,以及栈是否已经初始化
    Pushif ((*S).top - (*S).base >= (*S).stacksize)检查栈是否已满,若满则需要扩容
    Popif (S == NULL ||( (*S).base == NULL)检查栈指针是否为空,以及栈是否已经初始化
    Popif ((*S).top == (*S).base)检查栈是否为空,若为空则不能进行弹栈操作
    StackTraverseif (S.base == NULL)检查栈是否已经初始化,未初始化则不能遍历
  • 关于遍历函数StackTraverse
    StackTraverse 函数的主要目的是遍历顺序栈 S 并对栈中的每个元素执行一个特定的操作。这个操作由传递给 StackTraverse 的函数指针 Visit 定义。

    Status StackTraverse(SqStack S, void(Visit)(SElemType))
    

    Visit 参数是一个函数指针,允许将函数作为参数传递给另一个函数。这里的 Visit 函数必须符合特定的格式:它需要是一个接受单个 SElemType 类型参数的函数。在遍历栈时,StackTraverse 函数会对栈中的每一个元素调用 Visit 函数。

    康建伟老师的程序中,PrintElem 函数被用作 Visit 函数,它的作用是打印一个整数元素:

    void PrintElem(SElemType e)
    {printf("%d ", e);
    }
    

    这样调用 StackTraverse 函数时:

    StackTraverse(S, PrintElem);
    
  • 核心代码主要就是下面这些
    (严书上用的是引用,这里用的是指针,能看懂就OK)

    /*** 初始化** 构建一个空栈S。初始化成功则返回OK,否则返回ERROR。*/
    Status InitStack(SqStack *S)
    {// 如果S为NULL,返回ERRORif (S == NULL){return ERROR;}// 为顺序栈分配一个大小为STACK_INIT_SIZE的数组空间(*S).base = (SElemType *)malloc(STACK_INIT_SIZE * sizeof(SElemType));if ((*S).base == NULL){// 存储分配失败exit(OVERFLOW);}// 设置栈顶指针为栈底指针(*S).top = (*S).base;// 设置栈的最大容量(*S).stacksize = STACK_INIT_SIZE;return OK;
    }/** 销毁(结构)** 释放顺序栈所占内存。*/
    Status DestroyStack(SqStack *S)
    {// 如果S为NULL,返回ERRORif (S == NULL){return ERROR;}// 释放顺序栈所占内存free((*S).base);// 栈底指针、栈顶指针置空(*S).base = NULL;(*S).top = NULL;// 栈的最大容量置为0(*S).stacksize = 0;return OK;
    }/** 清空(内容)** 只是清理顺序栈中存储的数据,不释放顺序栈所占内存。*/
    Status ClearStack(SqStack *S)
    {// 如果S为NULL或者S本身就是空栈,则返回ERRORif (S == NULL || (*S).base == NULL){return ERROR;}(*S).top = (*S).base;return OK;
    }/*** 判空** 判断顺序栈中是否包含有效数据。*/
    Status StackEmpty(SqStack S)
    {// 如果栈顶指针和栈底指针重合,则说明栈为空if (S.top == S.base){return TRUE;}else{return FALSE;}
    }/*** 计数** 返回顺序栈包含的有效元素的数量。*/
    int StackLength(SqStack S)
    {if (S.base == NULL){return 0;}return (int)(S.top - S.base);
    }/*** 取值** 获取栈顶元素,并通过e返回。*/
    Status GetTop(SqStack S, SElemType *e)
    {if (S.base == NULL || S.top == S.base){return ERROR;}*e = *(S.top - 1);
    }/*** 压栈** 将元素e压入到栈顶。*/
    Status Push(SqStack *S, SElemType e)
    {if (S == NULL || (*S).base == NULL){return ERROR;}// 如果栈满,则追加存储空间if ((*S).top - (*S).base >= (*S).stacksize){// 为顺序栈追加空间(*S).base = (SElemType *)realloc((*S).base, ((*S).stacksize + STACKINCREMENT) * sizeof(SElemType));if ((*S).base == NULL){// 存储分配失败exit(OVERFLOW);}// 栈容量加上增量(*S).top = (*S).base + (*S).stacksize;(*S).stacksize += STACKINCREMENT;}// 入栈先赋值,栈顶指针再加1*(S->top) = e; // 也可以写成:*((*S).top)=e;S->top++;
    }/*** 弹栈** 将栈顶元素弹出,并通过e返回。*/
    Status Pop(SqStack *S, SElemType *e)
    {if (S == NULL || (*S).base == NULL){return ERROR;}// 如果栈为空,则返回ERRORif ((*S).top == (*S).base){return ERROR;}// 栈顶指针减1,将栈顶元素赋值给e(*S).top--;*e = *((*S).top);return OK;
    }/*** 遍历** 用visit函数访问顺序栈S*/
    Status StackTraverse(SqStack S, void(Visit)(SElemType))
    {if (S.base == NULL){return ERROR;}SElemType *p = S.base;while (p < S.top){Visit(*p++);}printf("\n");return OK;
    }
    
http://www.15wanjia.com/news/16293.html

相关文章:

  • 网站开发待遇怎么样十大骗子教育培训机构
  • wordpress 资源站主题seo网站推广是什么意思
  • 网站设计教程网站seo关键词快速排名
  • 昆明网站建设php上海seo网站推广
  • 555建筑网上海谷歌seo
  • 如何快速建设推广网站seo服务外包客服
  • 南京驰铭做网站公司利搜网站排名软件
  • 镇江地区做网站的公司crm系统成功案例分享ppt
  • 吉林省长春市建设局网站百度关键词网站排名优化软件
  • 定制网站建设开发渠道推广策略
  • 网站后台做1个多少钱网站制作价格
  • 长治市建设局网站网站推广网站
  • 小红门网站建设怎样做公司网站推广
  • 北方工业大学网站建设互联网推广公司
  • 南昌房产网二手房优化大师免费版下载
  • 做的网站图片不显示国内好的seo
  • 桂林网站排名做网站公司
  • wordpress米表域名展宁波seo外包引流推广
  • 江西网站开发多少钱百度推广登陆入口官网
  • 做网站java好还是.net好开封网站快速排名优化
  • 番禺做网站企业百度推广登录账号首页
  • 昆明网站免费制作廊坊seo优化排名
  • java 框架用来做网站网络营销论文题目
  • 深圳建站费用搜索引擎优化的分类
  • 公司企业logo设计宁德seo
  • 饥荒网站这么做2022年seo最新优化策略
  • 成立网站要多少钱一个人怎么做独立站shopify
  • 免费申请域名的网站包就业的培训学校
  • 个人做旅游网站怎样seo外链技巧
  • 用discuz做交友网站天津百度优化