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

学做网站论坛好吗免费建自己的网址

学做网站论坛好吗,免费建自己的网址,网站屏蔽中国ip,做的网站被注销下题目为个人的刷题记录,在本节博客中我将详细谈论设计循环队列的思路,并给出代码,有需要借鉴即可。 题目:LINK 循环队列是线性表吗?或者说循环队列是线性结构吗? 对于这个问题,我们来看一下线…

下题目为个人的刷题记录,在本节博客中我将详细谈论设计循环队列的思路,并给出代码,有需要借鉴即可。

题目:LINK
在这里插入图片描述
循环队列是线性表吗?或者说循环队列是线性结构吗?
对于这个问题,我们来看一下线性结构的定义:
在这里插入图片描述
因为循环队列结点个数为k个,且具有逻辑结构性,因此属于一种特殊的线性结构

下面是思路分析:
首先一开始收到实现普通队列的思路影响+上题目中循环这俩字,那自然想到的是用链表来设计循环队列。
于是,为了便于分析我作了下面的草图:
在这里插入图片描述
现在我们一开始迎来了第一个问题:我们的头指针和尾指针初始化放到哪里?
为了解决这个问题,我想到了第一个方法:初始化头指针尾指针置为空
这个方法看似很好,但是结合一下我们要实现的接口,判空时候需要做特殊处理,其实并不是很好。
在这里插入图片描述
然后我又想到,那让他们一开始直接都指向第一个结点
我们继续往下想,如果这样做的化,还是那个问题,如何区分空队列与一个结点的情况?
在这里插入图片描述
那么为了解决这个区分问题,我们可以引入size来统计结点个数
在这里插入图片描述
不过这里还有个问题,如果front与rear初始化指向第一个结点,然后引入size来区分结点个数的话,我们发现rear是指向尾结点的后一个结点的,也就是说我们在搞取尾接口的时候并不好操作,因为这是单向链表。
在这里插入图片描述
那为了解决取尾接口问题,我们要把单链表改成双向链表
但是这样一来,工作量就要变大很多,并不是很好的选择。
所以,不妨我们来用一下数组:
1.为了解决两个指针一开始都指向第一个空间特殊处理的问题,所以我们选择rear指向尾结点的后一个结点
2.为了解决不好判断的问题,我们多开一个空间,用rear+1 == front 为满的条件
3.为了解决数组循环问题,我们可以取模

下面是示例代码:


typedef struct {int front;//头元素int rear;//尾元素的下一个int* arr;//数组指针int k;
} MyCircularQueue;//检查循环队列是否为空
bool myCircularQueueIsEmpty(MyCircularQueue* obj) {if(obj->front == obj->rear){return true;}else{return false;}
}bool myCircularQueueIsFull(MyCircularQueue* obj) {if((obj->rear+1)%(obj->k+1)==obj->front){return true;}else{return false;}
}//构造器,设置队列长度为 k 
MyCircularQueue* myCircularQueueCreate(int k) {//首先创造出一个MyCircularQueue结构体,为方便操作数组做铺垫MyCircularQueue* obj = (MyCircularQueue*)malloc(sizeof(MyCircularQueue));//数组空间申请+初始化结构体obj->arr = (int*)malloc((k+1)*sizeof(int));obj->k = k;obj->front = obj->rear = 0;//返回结构体指针return obj;
}//向循环队列插入一个元素。如果成功插入则返回真
bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {//满了if(myCircularQueueIsFull(obj)){return false;}else//没满{obj->arr[obj->rear++] = value;//放入数据并移动尾指针obj->rear = obj->rear % (obj->k+1);//循环return true;}
}
//从循环队列中删除一个元素。如果成功删除则返回真
bool myCircularQueueDeQueue(MyCircularQueue* obj) {//空的if(myCircularQueueIsEmpty(obj)){return false;}else//非空{obj->front++;obj->front %= (obj->k+1);return true;}
}//从队首获取元素。如果队列为空,返回 -1 
int myCircularQueueFront(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))//为空{return -1;}else//非空{return obj->arr[obj->front];}
}//获取队尾元素。如果队列为空,返回 -1 
int myCircularQueueRear(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))//为空{return -1;}else{int prear = ((obj->rear + obj->k)%(obj->k+1));return obj->arr[prear];}
}void myCircularQueueFree(MyCircularQueue* obj) {free(obj->arr);free(obj);
}/*** Your MyCircularQueue struct will be instantiated and called as such:* MyCircularQueue* obj = myCircularQueueCreate(k);* bool param_1 = myCircularQueueEnQueue(obj, value);* bool param_2 = myCircularQueueDeQueue(obj);* int param_3 = myCircularQueueFront(obj);* int param_4 = myCircularQueueRear(obj);* bool param_5 = myCircularQueueIsEmpty(obj);* bool param_6 = myCircularQueueIsFull(obj);* myCircularQueueFree(obj);
*/

完。

http://www.yidumall.com/news/97938.html

相关文章:

  • smart video wordpress太原seo服务
  • 织梦快速做双语网站网站在线客服系统 免费
  • 网站后端开发是什么企业自助建站
  • 网站毕设代做多少钱跨境电商哪个平台比较好
  • 公网动态ip如何做网站怎样淘宝seo排名优化
  • 怎么在外国网站上找产品做跨境电商市场营销毕业论文
  • 传媒公司网站制作深圳网络优化seo
  • 博罗网站建设2022年最新新闻播报稿件
  • wordpress语言插件qx百度官网优化
  • 网站底部友情链接怎么做的随州seo
  • 菏泽网站建设公司蓝希科技市场调研模板
  • 网站建设的类型手机推广app
  • 石家庄招标信息网网络优化论文
  • 专业做网站优化需要多久兴安盟新百度县seo快速排名
  • 通辽网站开发seo工具网站
  • 能看街景的软件百度关键词seo外包
  • 天津河西做网站公司网络营销公司怎么注册
  • 包头哪里做网站微信指数查询
  • 萝岗企业网站建设深圳seo
  • 辛集专业网站建设中国的搜索引擎有哪些
  • 建站公司用哪家服务器北京网站建设制作公司
  • 南宁做网站开发的公司有哪些工业和信息化部
  • 腾讯企业邮箱基础版注册南昌seo优化
  • 怎么查公司网站有没有被收录西安百度关键词包年
  • 好网站设计公司网站流量统计查询
  • 天津专业做网站公司电商培训视频教程
  • 镇江网站杭州百度快照推广
  • 网站开发服务协议深圳专业建站公司
  • 宁波网站推广宣传公司排名seo自学网官方
  • 网站制作评价求好用的seo软件