• 王道数据结构——顺序循环队列


    循环队列的顺序存储
     

    代码如下:

    1. #include
    2. #define Maxsize 20
    3. typedef struct
    4. {
    5. int data[Maxsize];
    6. int front,rear;
    7. }SqQueue;
    8. void InitQueue(SqQueue &Q)
    9. {
    10. Q.front=1;
    11. Q.rear=1;
    12. }
    13. bool IsEmpty(SqQueue Q)
    14. {
    15. if(Q.front==Q.rear) return true;
    16. else return false;
    17. }
    18. void Push(SqQueue &Q,int x)
    19. {
    20. if(Q.front==(Q.rear+1)%Maxsize)
    21. {
    22. printf("队满了\n");
    23. }
    24. Q.data[Q.rear]=x;
    25. Q.rear=(Q.rear+1)%Maxsize;
    26. }
    27. void Pop(SqQueue &Q,int &y)
    28. {
    29. if(Q.front==Q.rear)
    30. {
    31. printf("队空了\n");
    32. }
    33. y=Q.data[Q.front];
    34. Q.front=(Q.front+1)%Maxsize;
    35. }
    36. void GetTop(SqQueue Q,int &z1)
    37. {
    38. z1=Q.data[Q.front];
    39. }
    40. void GetTail(SqQueue Q,int &z2)
    41. {
    42. z2=Q.data[Q.rear-1];
    43. }
    44. int LenQueue(SqQueue Q)
    45. {
    46. // int len;
    47. // len=(Q.rear-Q.front+Maxsize)%Maxsize;
    48. // return len;
    49. return (Q.rear+Maxsize-Q.front)%Maxsize;
    50. }
    51. int main()
    52. {
    53. SqQueue Q;
    54. InitQueue(Q);
    55. printf("%d\n",IsEmpty(Q));
    56. // int x;
    57. // scanf("%d",&x);
    58. // Push(Q,x);
    59. Push(Q,150);
    60. Push(Q,500);
    61. Push(Q,985);
    62. printf("%d\n",IsEmpty(Q));
    63. int y;
    64. Pop(Q,y);
    65. printf("当前出队的队首元素为%d\n",y);
    66. int z1,z2;
    67. GetTop(Q,z1);
    68. GetTail(Q,z2);
    69. printf("队首元素为%d\n",z1);
    70. printf("队尾元素为%d\n",z2);
    71. printf("当前队列的队长是%d\n",LenQueue(Q));
    72. return 0;
    73. }
    74. /*
    75. 150 500 985
    76. */

  • 相关阅读:
    MySQL高可用之MHA集群
    Nodejs 第五十四章(net)
    Linux 目录说明 常见方法
    Linux 权限系统
    ES6中的set、map
    js回调函数
    Linux使用wegt下载ftp内容及定时器设置
    基于Java Web的汽车租赁系统的设计与实现
    泰迪杯A题通讯产品销售和盈利能力分析一等奖作品
    Windows 快捷方式
  • 原文地址:https://blog.csdn.net/UncleJokerly/article/details/126179711