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

如何建立网络平台seo网站推广优化

如何建立网络平台,seo网站推广优化,一个人看的免费视频高清直播,做网站的可以信吗💕休对故人思故国,且将新火试新茶,诗酒趁年华💕 作者:Mylvzi 文章主要内容:详解链表OJ题 前言: 前面已经学习过顺序表,链表。他们都是线性表,今天要学习的栈也是一种线…

 

   💕休对故人思故国,且将新火试新茶,诗酒趁年华💕

作者:Mylvzi 

 文章主要内容:详解链表OJ题 

前言:

        前面已经学习过顺序表,链表。他们都是线性表,今天要学习的栈也是一种线性表。那么,什么是栈呢?栈又是如何实现对数据的管理呢,下面进行讲解。

栈的定义:

        栈就是一种只能在栈顶进行元素的添加删除的线性表。具有“后进先出”的特性,就是后面进入的元素反而首先被删除!所以栈的这种结构又被称为LIFO结构(Last In First Out);

        我们可以把栈理解为枪的的弹夹,试想,每次压子弹的时候是不是只能从一端插入?先插入的子弹会被先打出去,子弹装填的过程对应着数据的进入,被称为“入栈”,而子弹的射出,对应着数据的删除,被称为“出栈”! 

栈的结构:

        我们知道,栈的最大特点就是只能在一端进行数据的添加和删除,那栈应该使用哪种结构来实现呢?是数组,还是链表呢?其实,最常使用的应该是数组。因为数组进行尾部数据的删除更简单!(数组的尾部就相当于栈顶),如果使用单链表,我们要保存上一结点的地址;如果使用双向链表,其结构没有数组简单;而且,数组对缓存的利用率要高于链表!能提高效率!

栈的实现:

        定义栈元素:

//定义栈元素
typedef int STDataType;typedef struct Stack
{STDataType* a;//存储数据int top;//栈顶int capacity;//容量
}ST;

         栈的初始化与删除:

//初始化栈
void STInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = 0;//代表栈顶下一个位置ps->capacity = 0;
}//删除栈
void STDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->top = 0;ps->capacity = 0;
}

        入栈和出栈 

//入栈
void STPush(ST* ps, STDataType x)
{assert(ps);//栈满要扩容if (ps->top == ps->capacity){//要考虑最开始top == capacity为0的情况//使用了三目运算符:为0,则新的容量值为4;不为0,新的容量值为原来的2倍int newcapacity = ps->capacity == 0 ? 4 : 2 * ps->capacity;STDataType* tmp = (STDataType*)realloc(ps->a, sizeof(STDataType)*newcapacity);if (tmp == NULL){perror("realloc");exit(-1);}//重新赋值ps->a = tmp;ps->capacity = newcapacity;}ps->a[ps->top] = x;ps->top++;
}//出栈
void STPop(ST* ps)
{assert(ps);//空assert(ps->a);ps->top--;//不需要管原来数据,直接让栈顶向前移动
}

        返回栈顶元素:

//返回栈顶元素
STDataType STTPop(ST* ps)
{assert(ps);assert(ps->a);//设置的top位最后一个元素的下一个位置return ps->a[ps->top - 1];
}

        计算元素个数和判断是否为空栈

//计算有效值个数
int STSize(ST* ps)
{assert(ps);//top就是栈内的数据个数return ps->top;
}//判断是否为空栈
bool STEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}

         总结:

        大家刚接触栈可能很疑惑栈的应用场景有哪些呢?举个例子,在我们上网时在某个网页遇到了一个吸引人的链接,你忍不住好奇心,点了进去,发现是不良网站,你想退到你原先浏览的界面,这是你就可以点击浏览器上方的后退键,就自动退回到原先的浏览界面。其实在这个过程中,一个一个的网页被“入栈”,你进去的不良网站就是栈顶元素,后退键其实是实现了“出栈”的一个过程;

        再比如画图软件中的“撤销”操作,本质上也是进行了“出栈”的操作;所以,栈的应用还是很广泛的,其他应用还需要大家自己摸索!

 

 

 

http://www.ds6.com.cn/news/52734.html

相关文章:

  • 专业个人网站在百度上打广告找谁推广产品
  • 中山响应式网站谷歌广告联盟
  • jquery网站引导插件站长统计性宝app
  • 任何判断网站SEO做的好坏电商运营培训大概多少学费
  • 网站建设 js怎么自己注册网站
  • 网站营销网站优化市场营销主要学什么
  • 短视频拍摄价目表seo数据监控平台
  • 网页制作软件dw还需要什么windows优化大师怎么彻底删除
  • 网站 建设制作菜鸟教程it培训
  • 网站快速盈利推广技术
  • 做软件下载网站违法吗百度导航下载2022最新版官网
  • 智慧团建重置密码验证码宁波seo关键词优化
  • 网站编辑属于什么行业长春关键词优化报价
  • 淄博外贸网站制作怎么免费推广自己网站
  • wordpress 新建模版武汉做seo公司
  • 青海网站建设公司哪家好百度网盘资源搜索引擎搜索
  • wordpress添加icoseo搜索引擎优化工程师招聘
  • 如何查询公司网站顶级域名百度推广优化方案
  • 广东省政府网站集约化建设百度广告推广怎么做
  • 自己如何制作网站网站建设公司是怎么找客户
  • 做的网站如何发更新抖音关键词搜索排名
  • 做三折页的网站百度一下你就知道官网网址
  • 网站建设高端网页设计seo排名推广
  • 网站专题页面百度关键词多少钱一个月
  • 长春网站制作顾问电商运营培训大概多少学费
  • 济南网站制作开通seo优化几个关键词
  • 建站平台 做网站软文写作是什么
  • 交易网站seo怎么做google谷歌搜索
  • 网站开发实训步骤市场调研报告内容
  • 河南新蔡有做网站建设的吗电商运营自学网站