5_11.C
上传用户:wyn840322
上传日期:2007-01-13
资源大小:294k
文件大小:4k
源码类别:

数据结构

开发平台:

C/C++

  1. /* ======================================== */
  2. /*    程式实例: 5_11.c                      */
  3. /*    使用数组来构建环状队列                */
  4. /* ======================================== */
  5. #define MAXQUEUE 10               /* 队列的最大容量      */
  6. int queue[MAXQUEUE];              /* 队列的数组宣告      */
  7. int front = -1;                   /* 队列的前端          */
  8. int rear = -1;                    /* 队列的后端          */
  9. /* ---------------------------------------- */
  10. /*  队列资料的存入                          */
  11. /* ---------------------------------------- */
  12. int enqueue(int value)
  13. {
  14.    if ( rear + 1 == front ||      /* 检查队列是否全满    */
  15.         (rear == (MAXQUEUE - 1) && front <= 0) )
  16.       return -1;                  /* 无法存入            */
  17.    rear++;                        /* 后端指标往前移      */
  18.    if ( rear == MAXQUEUE )        /* 是否超过界限        */
  19.       rear = 0;                   /* 从头开始            */
  20.    queue[rear] = value;           /* 存入队列            */
  21. }
  22. /* ---------------------------------------- */
  23. /*  队列资料的取出                          */
  24. /* ---------------------------------------- */
  25. int dequeue()
  26. {
  27.    if ( front  == rear )          /* 检查队列是否是空    */
  28.       return -1;                  /* 无法取出            */
  29.    front++;                       /* 前端指标往前移      */
  30.    if ( front == MAXQUEUE )       /* 是否超过界限        */
  31.       front = 0;                  /* 从头开始            */
  32.    return queue[front];           /* 队列取出            */
  33. }
  34. /* ---------------------------------------- */
  35. /*  主程式: 模拟队列操作                    */
  36. /*  输出输入的内容都会储存於数组中, 接着列  */
  37. /*  印出数组内容来看其结果.                 */
  38. /* ---------------------------------------- */
  39. void main()
  40. {
  41.    int input[100];                /* 储存输入的元素      */
  42.    int output[100];               /* 储存取出的元素      */
  43.    int select;                    /* 选择项1,2,或3       */
  44.    int i_count = 0;               /* 数组input的索引     */
  45.    int o_count = 0;               /* 数组output的索引    */
  46.    int loop = 1;                  /* 回路控制            */
  47.    int i,temp;                    
  48.    while ( loop )                 /* 主回路开始          */
  49.    {
  50.       /* 选项内容 */
  51.       printf("[1]输入 [2]取出 [3]列出全部内容 ==> ");
  52.       scanf("%d",&select);        /* 读入选项            */
  53.       switch ( select )
  54.       {
  55.          /* 输入值后将之存入队列 */
  56.          case 1: printf("请输入存入队列的值(%d) ==> ",
  57.                          i_count + 1);
  58.                  scanf("%d",&temp);
  59.                  if ( enqueue(temp) == -1 )
  60.                     printf("队列全满.n");
  61.                  else
  62.                     input[i_count++] = temp;
  63.                  break;
  64.          /* 取出队列的内容 */
  65.          case 2: if ( (temp = dequeue()) == -1 )
  66.                     printf("队列是空的.n");
  67.                  else
  68.                  {
  69.                     printf("取出队列元素: %dn",temp);
  70.                     output[o_count++] = temp;
  71.                  }
  72.                  break;
  73.          /* 离开回路 */
  74.          case 3: loop = 0;        /* 设定loop为零        */
  75.                  break;
  76.       }
  77.    }
  78.    printf("输入队列的元素: ");    /* 输出结果            */
  79.    for ( i = 0; i < i_count; i++ )     /* 列印回路       */
  80.       printf("[%d]",input[i]);
  81.    printf("n取出队列的元素: ");
  82.    for ( i = 0; i < o_count; i++ )     /* 列印回路       */
  83.       printf("[%d]",output[i]);
  84.    printf("n剩下队列的元素: ");
  85.    while ( (temp = dequeue()) != -1 )  /*取出剩下队列元素*/
  86.       printf("[%d]",temp);
  87.    printf("n");                       /* 换行           */
  88. }