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

外贸网站该怎么做公众号关键词排名优化

外贸网站该怎么做,公众号关键词排名优化,计算机网站的开发流程,天津建设网查询分数一、概念 栈是一种先进后出的数据结构。FILO(firt in late out) 逻辑结构:线性结构 二、存储结构: (一) 顺序存储 顺序栈 基于一个数组配合一个栈顶"指针(数组下标)–top" 顺序栈的本质就是对…

一、概念

栈是一种先进后出的数据结构。FILO(firt in late out)
逻辑结构:线性结构

二、存储结构:

(一) 顺序存储

顺序栈
基于一个数组配合一个栈顶"指针(数组下标)–top"
顺序栈的本质就是对顺序表操作的一种约束:只能在一端进行插入和删除。

操作:
创建
清空
销毁
入栈、压栈——判断栈满
出栈、弹栈——判断栈空
打印栈所有元素

(二)链式存储

1. 结构体定义

//链表节点结构体----数据元素
typedef struct _Node{int data;struct _Node *next;
}node_t;//链式栈的结构体----数据对象
typedef struct _Stack{node_t *top;int count;//记录栈中元素个数//.....其他属性信息
}stack_t;

2.创建栈表

(1)函数定义

int create_stack(stack_t **my_stack);

  1. 在内存中申请一块stack_t类型大小的空间存储栈的内容;
  2. 初始化栈的成员的数据:将count置0,top置NULL
(2)注意点
  1. 进入函数就需要判断传入的参数是否为NULL,为空退出函数
  2. 在申请完内存空间后判断,申请空间是否成功,失败退出函数
(3)代码实现
int create_stack(stack_t **my_stack){if(NULL==my_stack) //判断传入参数是否为空{return -1;}*my_stack=(stack_t *)malloc(sizeof(stack_t));if(NULL==*my_stack){return -1;}//初始化(*my_stack)->top=NULL;(*my_stack)->count=0;return 0;
}

3. 入栈

(1)函数定义

int push_stack(stack_t *my_stack, int data);

  1. 在内存中申请一块node_t类型大小的数据空间
  2. 进行头插
  3. count自加一
(2)注意点
  1. 需要检查传入参数是否为空,为空退出函数
  2. top指向的元素即是第一个数据节点
(3)代码实现
int push_stack(stack_t *my_stack, int data){if(NULL==my_stack){return -1;}//申请一个新数据节点node_t *node=(node_t *)malloc(sizeof(node_t));if(NULL==node){return -1;}node->next=my_stack->top;my_stack->top=node;node->data=data;my_stack->count++;return 0;
}

3. 出栈

(1)函数定义

int pop_stack(stack_t *my_stack, int *num);

  1. 头删
  2. count自减
(2)注意点
  1. 需要检查传入指针参数和*num是否为空,为空退出函数
  2. 检查栈是否为空,为空退出函数
(3)代码实现
//出栈
int pop_stack(stack_t *my_stack, int *num){if(NULL==my_stack||NULL==num){return -1;}if(is_empty(my_stack)){return -1;}//头删node_t *pdel=my_stack->top;*num=pdel->data;my_stack->top=pdel->next;free(pdel);pdel=NULL;my_stack->count--;return 0;
}

4. 判断栈是否为空

(1)函数定义

int is_empty(stack_t *my_stack);

(2)注意点
  1. 判断传入的指针参数是否为空
(3)代码实现
int is_empty(stack_t *my_stack){if(NULL==my_stack){return -1;}return (my_stack->count)?0:1; 
}

5. 清空栈

(1)函数定义

int clean_stack(stack_t *my_stack);

  1. 循环头删
  2. count置0
  3. 只要top的指向不为空,就一直循环
(2)注意点
  1. 入参合理性检查
  2. count不要忘记置0
(3)代码实现
int clean_stack(stack_t *my_stack){if(NULL==my_stack){return -1;}node_t *pdel=NULL;while(my_stack->top){pdel=my_stack->top;my_stack->top=pdel->next;free(pdel);}pdel=NULL;my_stack->count=0;return 0;
}

6. 销毁栈

(1)函数定义

int destroy_stack(stack_t **my_stack);

(2)注意点
(3)代码实现
int destroy_stack(stack_t **my_stack){if(NULL==my_stack||NULL==*my_stack){return -1;}//先清空再销毁if(clean_stack(*my_stack)){return -1;}free(*my_stack);*my_stack=NULL;return 0;
}

7. 打印栈

(1)函数定义

int print_stack(stack_t *my_stack);

(2)注意点
  1. 入参合理性检查
(3)代码实现
int print_stack(stack_t *my_stack){if(NULL==my_stack){return -1;}if(is_empty(my_stack)){printf("栈空\n");return -1;}node_t *ptemp=my_stack->top;for(int i=0;i<my_stack->count;i++){printf("%d ",ptemp->data);ptemp=ptemp->next;}putchar(10);return 0;
}
http://www.mmbaike.com/news/83082.html

相关文章:

  • 佛山网站制作优化软件刷排名seo
  • 交友网站怎样做在线之家
  • 网站制作案例怎么样热搜榜排名今日第一
  • 中信建设有限责任公司官网招聘信息百度地图优化排名方法
  • 九江网站建设哪家公司好深圳seo技术
  • 跟随网站滚动的悬浮框怎么做今日国内新闻热点
  • 网站多ip 建设网络营销推广的方式
  • 一般找人做网站多少钱口碑营销的优势
  • 把织梦改成字段式网站广告免费推广网
  • 提供手机自适应网站制作如何广告推广
  • 网站界面 欣赏网站网络排名优化方法
  • 空间商指定的网站目录百度霸屏推广
  • 潍坊网站制作维护进入百度搜索首页
  • 专门做租房的网站指数网站
  • 顺德网站制作案例平台网络推广员的日常工作
  • 网站中页面链接怎么做的成品视频直播软件推荐哪个好用
  • 专业网站建设哪里找美国疫情最新数据消息
  • 新零售商业模式外贸seo软件
  • 深圳网站建设公司建设短视频培训学校
  • 金融理财网站建设方案福州短视频seo公司
  • bitcoind 做交易网站seo点击器
  • 郑州做网站的公司排名重庆百度seo公司
  • 宁波网站搜索优化app推广软文范文
  • 做网站java要什么优化设计答案五年级上册
  • 网站开发需要什么服务器网络推广引流是做什么的
  • 烟台h5网站制作搜索引擎有哪些网站
  • 湄潭建设局官方网站2021百度模拟点击工具
  • 网站闭站品牌推广软文
  • 自己做商城网站百度热度榜搜索趋势
  • 制作网站哪家便宜手机网站自助建站系统