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

网站开发工具seo网站关键词排名软件

网站开发工具,seo网站关键词排名软件,做化工的外贸网站都有什么,网站建设经验分享前言 队列是一种特殊的线性表,它只允许在一端对数据进行插入操作,在另一端对数据进行删除操作的特殊线性表,队列具有先进先出的(FIFO)的 特性,进行插入操作的一端称为队尾,进行删除操作的一端称…

前言

        队列是一种特殊的线性表,它只允许在一端对数据进行插入操作,在另一端对数据进行删除操作的特殊线性表,队列具有先进先出的(FIFO)的 特性,进行插入操作的一端称为队尾,进行删除操作的一端称为队头。

1.队列的特性

        队尾:元素在队尾入队。插入操作。

        队头:元素在队头出对。删除操作。

如图:

2.队列的实现

         队列可以用 数组和链表的结构实现,使用链表的结构实现更优一些,因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低,需要挪动数据,因此这里采用链表的方式来进行队列的实现。

//queue.h

#include<stdlib.h>
#include<assert.h>
#include<stdio.h>
#include<stdbool.h>
typedef int QDataType;
typedef struct QueueNode
{struct QueueNode* _next;QDataType _data;
}QueueNode;
typedef struct  Queue//队列的结构
{QueueNode* _head;//头指针QueueNode* _tail;//尾指针
}Queue;void QueueInit(Queue* qu);//初始化栈void QueueDestory(Queue* qu);//摧毁栈void QueuePush(Queue* qu,QDataType data);//入队void QueuePop(Queue* qu);//出队QDataType QueueFront(Queue* qu);//返回队头元素
QDataType QueueBack(Queue* qu);//返回队尾元素size_t QueueSize(Queue* qu);//队列长度bool QueueEmpty(Queue* qu);//判断队列是否为空

//queue.c

void QueueInit(Queue* qu)//初始化栈
{qu->_head = qu->_tail = NULL;
}
void QueueDestory(Queue* qu)//摧毁栈
{//确保指针有效assert(qu);QueueNode* cur = qu->_head;while (cur){QueueNode* next = cur->_next;free(cur);}
}
void QueuePush(Queue* qu,QDataType data)//入队
{if (qu->_head == NULL){qu->_head = (QueueNode*)malloc(sizeof(QueueNode));qu->_tail = qu->_head;qu->_head->_next = NULL;qu->_head->_data = data;}else{//尾部入数据QueueNode* cur = qu->_tail;QueueNode* newNode = (QueueNode*)malloc(sizeof(QueueNode));cur->_next = newNode;newNode->_next = NULL;qu->_tail = newNode;newNode->_data = data;}
}
void QueuePop(Queue* qu)//出队
{//队头出数据QueueNode* head = qu->_head;qu->_head = head->_next;free(head);
}
QDataType QueueFront(Queue* qu)//返回队头元素
{return qu->_head->_data;
}
QDataType QueueBack(Queue* qu)//返回队尾元素
{return qu->_tail->_data;
}
size_t QueueSize(Queue* qu)//队列长度
{assert(qu);//确保指针存在QueueNode* cur = qu->_head;size_t size = 0;while (cur){++size;cur = cur->_next;}return size;
}
bool QueueEmpty(Queue* qu)//判断队列是否为空
{return !qu->_head;
}

 

3.测试部分

        

void TestQueue()
{Queue qu;QueueInit(&qu);QueuePush(&qu, 1);QueuePush(&qu, 2);QueuePush(&qu, 3);QueuePush(&qu, 4);QueuePush(&qu, 5);QueuePush(&qu, 6);QueuePush(&qu, 7);QueuePush(&qu, 8);while (!QueueEmpty(&qu)){printf("%d ", QueueFront(&qu));QueuePop(&qu);}QueueDestory(&qu);
}

 

http://www.dinnco.com/news/24617.html

相关文章:

  • 做婚恋网站怎么样个人对网络营销的看法
  • 制作酒店网站代运营一般收费
  • 肥西做网站seo入门教学
  • 做网站用的什么空间搜索引擎关键词排名
  • a做片手机免费网站有哪些深圳百度seo代理
  • logo设计欣赏seo每日一帖
  • 隧道建设网站怎么了足球排名最新排名世界
  • 长沙网站制作app开发公司国际网络销售平台有哪些
  • 爱站网功能品牌seo主要做什么
  • 建设网站及域名费用免费建立网站步骤
  • 俄罗斯女孩制作论文网站西安网站建设网络推广
  • 湖州网站建设服务公司站长之家最新域名查询
  • 专业做旅游网站分析网站
  • html网站开场动画效果模板营销渠道名词解释
  • 重庆市互联网协会什么是网站优化
  • 2狠狠做网站首页排名seo
  • 制作网站的公司哪个部门监管百度搜索关键词
  • 开福区互动网站建设自媒体论坛交流推荐
  • 做宣传单页的网站百度金融
  • wordpress 搭建网站广州今日头条新闻
  • 贵州网站制作企业营销策略
  • 多个网站 备案吗怎么优化
  • 重庆建设工程信息网证书查询系统广州seo公司排行
  • 加强网站 网站建设网址域名注册信息查询
  • 视频网站弹幕怎么做1688官网入口
  • 搞一个网站需要多少钱一个网站可以优化多少关键词
  • ui做的好的公司网站汕头seo外包平台
  • 中山网站建设 760写软文的平台有哪些
  • 怎么建手机网站seo外链在线提交工具
  • 企业网站规划方案什么是seo技术