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

政府网站设计欣赏广告推广公司

政府网站设计欣赏,广告推广公司,dedecms生成网站地图,武汉网站排名引言 在对顺序表,链表有了充分的理解之后,现在让我们学习栈和队列!!! 【链表】 👈链表 【顺序表】👈顺序表 目录 💯栈 1.栈的概念及结构 2.栈的实现 ⭐初始化栈 ⭐入栈 ⭐…

引言

在对顺序表,链表有了充分的理解之后,现在让我们学习栈和队列!!!

【链表】    👈链表

【顺序表】👈顺序表

目录

💯栈

1.栈的概念及结构

2.栈的实现

⭐初始化栈

⭐入栈

⭐出栈

⭐获取栈顶元素

⭐获取栈中有效元素个数

⭐检测栈是否为空

⭐销毁栈

✨实现结果

💯队列

1.队列的概念及结构

2.列队的实现 

⭐初始化列队

⭐队尾入列队

⭐队尾出列队

⭐获取队列头部元素

⭐获取队列中有效元素个数

⭐检测队列是否为空 

⭐销毁列队

✨实现结果


💯栈

1.栈的概念及结构

  • 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。
  • 压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶
  • 出栈:栈的删除操作叫做出栈。出数据也在栈顶

先进后出 (Last In First Out

让我们思考下面2道题目,加深对栈的理解: 

2.栈的实现

栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价比较小。

// 下面是定长的静态栈的结构,实际中一般不实用,所以我们主要实现下面的支持动态增长的栈
typedef int STDataType;
#define N 10
typedef struct Stack
{STDataType _a[N];int _top; // 栈顶
}Stack;
// 支持动态增长的栈
typedef int STDataType;
typedef struct Stack
{STDataType* _a;int _top; // 栈顶int _capacity; // 容量
}Stack;// 初始化栈
void StackInit(Stack* ps);// 入栈
void StackPush(Stack* ps, STDataType data);// 出栈
void StackPop(Stack* ps);// 获取栈顶元素
STDataType StackTop(Stack* ps);// 获取栈中有效元素个数
int StackSize(Stack* ps);// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0
bool StackEmpty(Stack* ps);// 销毁栈
void StackDestroy(Stack* ps);
⭐初始化栈
typedef int STDateType;
typedef struct Stack
{STDateType* a;int top;int capacity;
}ST;
⭐入栈
void StackPush(ST* p, STDateType x)
{if (p->top == p->capacity){STDateType* temp = (STDateType*)realloc(p->a, p->capacity * 2*sizeof(STDateType));if (temp==NULL){printf("realloc fail\n");exit(-1);}else{p->capacity *= 2;p->a = temp;}}p->a[p->top] = x;p->top++;
}
⭐出栈
void StackPoP(ST* p)
{assert(p);assert(p->top>0);p->top--;
}
⭐获取栈顶元素
STDateType StackTop(ST* p)
{assert(p);assert(p->top > 0);return p->a[p->top - 1];
}
⭐获取栈中有效元素个数
int Size(ST* p)
{return p->top;
}
⭐检测栈是否为空

        如果为空返回非零结果,如果不为空返回0

bool StackEmpty(ST* p)
{return p->top == 0;
}
⭐销毁栈
void StackDestory(ST* p)
{assert(p);free(p->a);p->a = NULL;p->capacity = p->top = 0;
}
实现结果
int main()
{ST p;StackInit(&p);StackPush(&p, 1);StackPush(&p, 2);StackPush(&p, 3);StackPush(&p, 4);StackPush(&p, 5);StackPush(&p, 6);while (!StackEmpty(&p)){printf("%d ", StackTop(&p));StackPoP(&p);}StackDestory(&p);return 0;
}


💯队列

1.队列的概念及结构

  • 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out)
  • 入队列:进行插入操作的一端称为队尾
  • 出队列:进行删除操作的一端称为队头

2.列队的实现 

队列的实现方式包括数组和链表。常见的队列实现方式有:

  1. 数组实现:使用一维数组存储元素,通过头指针和尾指针分别指向队头和队尾实现入队和出队操作。
  2. 链表实现:每个元素使用一个节点存储,通过指针链接实现队列,入队操作在链表末尾插入新节点,出队操作删除链表头节点。                                  从head端删除元素,从tail端插入元素
  • 队列也可以数组和链表的结构实现,使用链表的结构实现更优一些。
  • 因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低。(需要将后面的元素集体前移)
// 链式结构:表示队列
typedef struct QListNode
{struct QListNode* _pNext;QDataType _data;
}QNode;// 队列的结构
typedef struct Queue
{QNode* _front;QNode* _rear;
}Queue;// 初始化队列
void QueueInit(Queue* q);// 队尾入队列
void QueuePush(Queue* q, QDataType data);// 队头出队列
void QueuePop(Queue* q);// 获取队列头部元素
QDataType QueueFront(Queue* q);// 获取队列中有效元素个数
int QueueSize(Queue* q);// 检测队列是否为空,如果为空返回非零结果,如果非空返回0
int QueueEmpty(Queue* q);// 销毁队列
void QueueDestroy(Queue* q);
⭐初始化列队
void QueueInit(Queue* pq)
{assert(pq);pq->head = pq->tail = NULL;pq->size = 0;
}
⭐队尾入列队
void QueuePush(Queue* pq, QDatatype x)
{QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail");return;}newnode->data = x;newnode->next = NULL;if (pq->head == NULL){assert(pq->tail == NULL);pq->head = pq->tail = newnode;}else{pq->tail->next = newnode;pq->tail = newnode;}pq->size++;
}
⭐队尾出列队
void QueuePop(Queue* pq)
{assert(pq);assert(pq->head != NULL);if (pq->head->next == NULL){free(pq->head);pq->head = pq->tail = NULL;}else{QNode* next = pq->head->next;free(pq->head);pq->head = next;}pq->size--;
}
⭐获取队列头部元素
QDatatype QueueFront(Queue* pq)
{assert(pq);assert(!QueueEmpty(pq));return pq->head->data;
}
⭐获取队列中有效元素个数
int QueueSize(Queue* pq)
{assert(pq);return pq->size;
}
⭐检测队列是否为空 

        如果为空返回非零结果,如果不为空返回0

bool QueueEmpty(Queue* pq)
{assert(pq);return pq->size == 0;
}
⭐销毁列队
void QueueDestroy(Queue* pq)
{assert(pq);QNode* cur = pq->head;while (cur){QNode* next = cur->next;free(cur);cur = next;}pq->head = pq->tail = NULL;pq->size = 0;
}
实现结果
int main()
{Queue p;QueueInit(&p);QueuePush(&p, 1);QueuePush(&p, 2);QueuePush(&p, 3);QueuePush(&p, 4);QueuePush(&p, 5);while (!QueueEmpty(&p)){printf("%d ",QueueFront(& p));QueuePop(&p);}QueueDestory(&p);return 0;
}


                                 💝💝💝以上就是本文章的全部内容啦~💝💝💝

感谢你看到最后,点个赞再走吧!

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。✨✨ 欢迎订阅本专栏 ✨✨

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

相关文章:

  • 手机版网站嵌入代码培训班招生方案
  • 凡科做的网站怎么样谷歌关键词优化怎么做
  • 网络营销官网windows优化大师官方
  • 网站建设公司南宁网站自动提交收录
  • 网站前台登录模板seo排名app
  • 律师网站建设平台外宣推广技巧
  • 简单网页的设计过程seo代码优化包括哪些
  • 福州百诚互联哈尔滨seo服务
  • 手机怎么做微电影网站网站黄页推广软件
  • web网站设计论文网站关键词优化推广哪家快
  • 多语种网站建设品牌广告投放
  • 天津房地产集团网站建设2023年8月份新冠
  • 如何再国外网站做折扣制作网站教学
  • 网站怎么做关键词怎么优化广州seo技术外包公司
  • web开发技术学什么seo项目完整流程
  • 商场商城网站建设方案百度小说排行榜风云榜
  • 音响厂家东莞网站建设优化网站最好的刷排名软件
  • 做宠物店网站的素材app推广怎么做
  • wordpress侧面分类插件seo经理招聘
  • 教育行业展示网站模板湖南关键词优化品牌价格
  • 手机网站一年维护费网络营销策划ppt范例
  • 做网站的职员称呼什么软文代写网
  • 广告制作公司如何经营西安seo全网营销
  • 酒店网站建设策划方案seo优化技巧
  • 沪尚茗居全包价格网站关键词优化多少钱
  • 织梦做的网站在百度搜索页劫取网站开发平台有哪些
  • 虚拟主机如何做网站国内搜索引擎
  • 做鲜榨果汁店网站营销型网页设计
  • app网站开发重庆怎么样才可以在百度上打广告
  • 网站 审批号营业推广怎么写