ZZZ_zzz555 2023-12-12 21:04 采纳率: 100%
浏览 6
已结题

数据结构队列中求长度的问题


int QueueLength(SqQueue Q){
    return (Q.rear - Q.front + MAXSIZE) % MAXSIZE;
}

我觉得直接返回Q.rear%MAXSIZE-Q.front%MAXSIZE也行吧,为什么还要加上MAXSIZE%MAXSIZE这个0呢?

  • 写回答

1条回答 默认 最新

  • K_n_i_g_h_t_1990 2023-12-13 19:39
    关注

    引用GPT
    循环队列是一种利用数组存储数据的线性表,它的特点是队头和队尾可以相连,形成一个环形的结构。循环队列的长度表示队列中有效元素的个数,它可以用队尾指针Q.rear和队头指针Q.front来计算。一种常见的计算公式是:

    $$QueueLength(Q) = (Q.rear - Q.front + MAXSIZE) % MAXSIZE$$

    其中,MAXSIZE是数组的容量,%是取余运算符。这个公式的意义是,无论Q.rearQ.front的相对位置如何,都可以得到一个非负的整数,表示队列的长度。例如,如果Q.rear > Q.front,那么Q.rear - Q.front就是队列的长度;如果Q.rear < Q.front,那么Q.rear - Q.front + MAXSIZE就是队列的长度;如果Q.rear == Q.front,那么队列为空,长度为0。

    你提出的另一种计算公式是:

    $$QueueLength(Q) = Q.rear % MAXSIZE - Q.front % MAXSIZE$$

    这个公式的问题是,它不能正确处理Q.rear < Q.front的情况。因为在这种情况下,Q.rear % MAXSIZE - Q.front % MAXSIZE会得到一个负数,而不是队列的长度。例如,如果Q.rear = 1Q.front = 3MAXSIZE = 5,那么Q.rear % MAXSIZE - Q.front % MAXSIZE = 1 - 3 = -2,而不是正确的长度3。所以,这个公式是错误的,不能用来计算循环队列的长度。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月21日
  • 已采纳回答 12月13日
  • 创建了问题 12月12日

悬赏问题

  • ¥15 STM32F103C8T6使用标准库stm32f10x.h驱动ws2812
  • ¥20 我是数控机床电气工程师,主要是做840DSL与one,请问如何自学
  • ¥20 显示器休眠后重新唤醒出现蓝屏,蓝屏代码为DRIVER-POWER.STATE-FAILURE
  • ¥20 alt+tab怎么恢复到以前的模式
  • ¥15 来一个会抓包app支付链接的
  • ¥15 MMdetection安装
  • ¥15 STM32U535系列stop3模式进入和RTC唤醒
  • ¥15 如何提取全民K歌没下载过但播放过很多次的音频?
  • ¥15 树莓派运行detect.py
  • ¥15 pdfplumber提起文本内容如何过滤水印内容