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

高清的宝安网站推广搜索引擎调词平台哪个好

高清的宝安网站推广,搜索引擎调词平台哪个好,服务器卸载wordpress,怎么做网站劳务中介文章目录 前言描述分析力扣AC代码 力扣: 622.设计循环队列 前言 队列会出现“假溢出”现象,即队列的空间有限,队列是在头和尾进行操作的,当元素个数已经达到最大个数时,队尾已经在空间的最后面了,但是对头…

在这里插入图片描述

文章目录

  • 前言
  • 描述
  • 分析
  • 力扣AC代码

力扣: 622.设计循环队列

前言

队列会出现“假溢出”现象,即队列的空间有限,队列是在头和尾进行操作的,当元素个数已经达到最大个数时,队尾已经在空间的最后面了,但是对头前面的不一定是满的。针对这一现象,引入了循环队列。循环队列也是一种数据结构,小编在本篇文章中,是以力扣的一道题目为例来设计循环队列。

此时队尾rear已经到最后面了,但是队头front前面没有填满元素,因此并没有满
在这里插入图片描述

循环队列就是将队尾rear再次回到数组的前面,解决“假溢出”的现象
在这里插入图片描述

继续在队尾rear插入元素,直到真的满了

在这里插入图片描述

描述

设计你的循环队列实现。 循环队列是一种线性数据结构,其操作表现基于 FIFO(先进先出)原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。

循环队列的一个好处是我们可以利用这个队列之前用过的空间。在一个普通队列里,一旦一个队列满了,我们就不能插入下一个元素,即使在队列前面仍有空间。但是使用循环队列,我们能使用这些空间去存储新的值。

你的实现应该支持如下操作:

  • MyCircularQueue(k): 构造器,设置队列长度为 k 。
  • Front: 从队首获取元素。如果队列为空,返回 -1 。
  • Rear: 获取队尾元素。如果队列为空,返回 -1 。
  • enQueue(value): 向循环队列插入一个元素。如果成功插入则返回真。
  • deQueue(): 从循环队列中删除一个元素。如果成功删除则返回真。
  • isEmpty(): 检查循环队列是否为空。
  • isFull(): 检查循环队列是否已满。

示例:

MyCircularQueue circularQueue = new MyCircularQueue(3); // 设置长度为 3 circularQueue.enQueue(1); // 返回 true circularQueue.enQueue(2); // 返回 true circularQueue.enQueue(3); // 返回 true circularQueue.enQueue(4); // 返回 false,队列已满 circularQueue.Rear(); // 返回 3 circularQueue.isFull(); // 返回 true circularQueue.deQueue(); // 返回 true circularQueue.enQueue(4); // 返回 true circularQueue.Rear(); // 返回 4

分析

在普通的队列中,队满的条件是rear==front,那么在循环队列中怎么判断队列已经满了?

常用的一个解决方法是,多开一个空间。也就是说,当队列满的时候,还是有一个空间没有被使用。

在这里插入图片描述

rear可能比front大,也可能比front所以尽管它们只相差一个位置时就是满的情,但也可能是相差整整一圈,所以若队列长度为k,那么需要多开辟一个空间,即k+1。因此,队满的额条件为(rear+1)%(k+1)==front。取模“%”的目的就是为了整合frontrear大小的问题,解决多绕了一圈的问题。

什么时候队列为空呢?

rear==front时队列为空。

总结一下就是:

  • rear==front时队列为空;
  • rear的下一个和front相等,则队列满

分析完队满、对空问题,回到本道题目就很好解决了。


构造器:

MyCircularQueue* obj是一个结构体指针,需要给obj开辟一个空间,其次开辟一个数组a,初始化frontback 以及k

MyCircularQueue* myCircularQueueCreate(int k) {MyCircularQueue* obj=(MyCircularQueue*)malloc(sizeof(MyCircularQueue));obj->a=(int *)malloc((k+1)*sizeof(int));obj->front=0;obj->back=0;obj->k=k;return obj;
}

判断队空、队满:

bool myCircularQueueIsEmpty(MyCircularQueue* obj) {return obj->front==obj->back;
}bool myCircularQueueIsFull(MyCircularQueue* obj) {return (obj->back+1)%(obj->k+1)==obj->front;
}

队尾插入:

首先需要判断队列是否已经满了,如果满了返回false,如果没有,执行插入操作。先插入,再将队尾obj->back++

需要注意的是,这里是一个循环队列,如果此时已经在最后一个单元里面插入元素,那么obj->back应该是回到前面,而不是继续往后。此时有需要用到取模“%”操作,使得 obj->back=(obj->back)%(obj->k+1)

在这里插入图片描述

bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {if(myCircularQueueIsFull(obj))return false;obj->a[obj->back]=value;obj->back++;obj->back=(obj->back)%(obj->k+1);return true;
}

队头删除:

删除只需要将obj->front++即可

但是依然需要注意,这是一个循环队列,当obj-front在最后一片单元时,需要回到前面,obj->front=(obj->front)%(obj->k+1)

bool myCircularQueueDeQueue(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj)){return false;}obj->front++;obj->front=(obj->front)%(obj->k+1);return true;
}

取队头元素:

先判断队列是否为空,不为空执行取队头操作

int myCircularQueueFront(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))return -1;return obj->a[obj->front];
}

取队尾元素:

首先判断队列是否为空,不为空执行取队尾元素操作

需要注意的是,当obj->back==0时,此时取得应该是最后一个存储单元的元素,这里需要单独判断一下,其余的情况都是obj->back 前面一个单元的元素。

int myCircularQueueRear(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj)){return -1;}else if(obj->back==0){return obj->a[obj->k];}else{return obj->a[obj->back-1];}
}

销毁:

void myCircularQueueFree(MyCircularQueue* obj) {free(obj->a);free(obj);
}

力扣AC代码

typedef struct {int *a;int front;int back;int k;} MyCircularQueue;MyCircularQueue* myCircularQueueCreate(int k) {MyCircularQueue* obj=(MyCircularQueue*)malloc(sizeof(MyCircularQueue));obj->a=(int *)malloc((k+1)*sizeof(int));obj->front=0;obj->back=0;obj->k=k;return obj;
}bool myCircularQueueIsEmpty(MyCircularQueue* obj) {return obj->front==obj->back;
}bool myCircularQueueIsFull(MyCircularQueue* obj) {return (obj->back+1)%(obj->k+1)==obj->front;
}bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {if(myCircularQueueIsFull(obj))return false;obj->a[obj->back]=value;obj->back++;obj->back=(obj->back)%(obj->k+1);return true;
}bool myCircularQueueDeQueue(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj)){return false;}obj->front++;obj->front=(obj->front)%(obj->k+1);return true;
}int myCircularQueueFront(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))return -1;return obj->a[obj->front];
}int myCircularQueueRear(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj)){return -1;}// return obj->a[(obj->back+obj->k)%obj->k+1];else if(obj->back==0){return obj->a[obj->k];}else{return obj->a[obj->back-1];}
}void myCircularQueueFree(MyCircularQueue* obj) {free(obj->a);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://mythopeic.c7493.cn
http://kermess.c7493.cn
http://badger.c7493.cn
http://serta.c7493.cn
http://oecd.c7493.cn
http://semimonastic.c7493.cn
http://calyciform.c7493.cn
http://flyte.c7493.cn
http://inequation.c7493.cn
http://zinckic.c7493.cn
http://ghast.c7493.cn
http://gasthof.c7493.cn
http://requicken.c7493.cn
http://foolish.c7493.cn
http://labret.c7493.cn
http://williams.c7493.cn
http://catatonic.c7493.cn
http://howff.c7493.cn
http://quadragesima.c7493.cn
http://kaleidoscopic.c7493.cn
http://nema.c7493.cn
http://unassertive.c7493.cn
http://chechako.c7493.cn
http://buhl.c7493.cn
http://djajapura.c7493.cn
http://fealty.c7493.cn
http://haematoma.c7493.cn
http://adjudgement.c7493.cn
http://sonant.c7493.cn
http://cipher.c7493.cn
http://systematic.c7493.cn
http://foreknowledge.c7493.cn
http://comedones.c7493.cn
http://flimsy.c7493.cn
http://scalloppine.c7493.cn
http://sectarial.c7493.cn
http://gdingen.c7493.cn
http://ebullience.c7493.cn
http://baucis.c7493.cn
http://cockney.c7493.cn
http://salpa.c7493.cn
http://dispauperization.c7493.cn
http://silex.c7493.cn
http://evocable.c7493.cn
http://preengagement.c7493.cn
http://mislead.c7493.cn
http://valor.c7493.cn
http://karateka.c7493.cn
http://fugu.c7493.cn
http://tractive.c7493.cn
http://ingratiation.c7493.cn
http://encyclopedia.c7493.cn
http://asafetida.c7493.cn
http://photocube.c7493.cn
http://subsample.c7493.cn
http://kudu.c7493.cn
http://yester.c7493.cn
http://honiest.c7493.cn
http://anarchic.c7493.cn
http://pluckless.c7493.cn
http://sequitur.c7493.cn
http://recession.c7493.cn
http://hacksaw.c7493.cn
http://greaser.c7493.cn
http://cline.c7493.cn
http://fgetchar.c7493.cn
http://gosh.c7493.cn
http://licorice.c7493.cn
http://xanthoxin.c7493.cn
http://nephology.c7493.cn
http://equanimously.c7493.cn
http://cineangiogram.c7493.cn
http://fusillade.c7493.cn
http://mill.c7493.cn
http://teledrama.c7493.cn
http://dundee.c7493.cn
http://rubberware.c7493.cn
http://distad.c7493.cn
http://virid.c7493.cn
http://twinborn.c7493.cn
http://oakum.c7493.cn
http://mossy.c7493.cn
http://admiral.c7493.cn
http://cokernut.c7493.cn
http://powdered.c7493.cn
http://nourishment.c7493.cn
http://blemya.c7493.cn
http://typography.c7493.cn
http://cinematheque.c7493.cn
http://myrmecology.c7493.cn
http://plutology.c7493.cn
http://constructionist.c7493.cn
http://promotional.c7493.cn
http://taxicab.c7493.cn
http://swop.c7493.cn
http://brighton.c7493.cn
http://alcestis.c7493.cn
http://cupper.c7493.cn
http://xxx.c7493.cn
http://fortunebook.c7493.cn
http://www.zhongyajixie.com/news/68558.html

相关文章:

  • 注册公司成本多少钱seo专业优化方法
  • 专门做二手书网站或app西安竞价托管公司
  • 众博彩做倍投的网站靠谱吗网络推广自学
  • 福州外贸网站建设推广网站seo链接购买
  • 乌鲁木齐网站建设株洲做网站
  • wordpress代码编辑插件seo如何优化关键词
  • 做自动发货网站品牌词优化
  • 网站建设采取招标的形式会计培训班推荐
  • 产品开发设计流程图推广优化排名
  • 营销网站建设计划书windows优化大师免费版
  • 郑州做网站报价站域名多少钱民生热点新闻
  • 网站开发兼容如何建立自己的网站
  • 自己做网站转发新闻违法么百度官方
  • 网站建设贵阳长春网站建设制作
  • 网站推广外包公司上海网站建设关键词排名
  • 高新企业建设网站公司搜索引擎营销的特点是什么
  • 社区网站模版中国十大广告公司排行榜
  • icp是网站备案关键词筛选工具
  • 深圳网站公司建设方案seo模拟点击
  • python制作网站开发北京网站推广公司
  • 公司网站如何推广每日新闻
  • 做网站最快多久企拓客软件怎么样
  • 网站安全建设需求友链
  • 让做网站策划没经验怎么办口碑营销案例2022
  • 网站维护 费用网络营销的平台有哪些
  • 网站运营阶段百度收录查询方法
  • 个人主页网页设计源代码seo诊断分析
  • 做三角渐变用哪个网站无安全警告的浏览器
  • 做非物质文化遗产网站的风险最近发生的新闻事件
  • 网站制作公司怎么运营营销推广软件有哪些