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

数据结构

开发平台:

C/C++

  1. /* ======================================== */
  2. /*    程式实例: 5_12.c                      */
  3. /*    使用链结串列来构建队列                */
  4. /* ======================================== */
  5. #include <stdlib.h>
  6. struct queue_node                 /* 队列结构的宣告     */
  7. {
  8.    int data;                      /* 资料               */
  9.    struct queue_node *next;       /* 结构指标           */
  10. };
  11. typedef struct queue_node queue_list;  /* 定义队列型态  */
  12. typedef queue_list *link;         /* 定义队列指标型态   */
  13. link front = NULL;                /* 队列的前端         */
  14. link rear = NULL;                 /* 队列的后端         */
  15. /* ---------------------------------------- */
  16. /*  队列资料的存入                          */
  17. /* ---------------------------------------- */
  18. int enqueue(int value)
  19. {
  20.    link new_node;
  21.    new_node = ( link ) malloc(sizeof(queue_list));
  22.    if ( !new_node )               /* 检查配置记忆体     */
  23.    {
  24.       printf("记忆体配置失败! n");
  25.       return -1;                  /* 无法存入           */
  26.    }
  27.    new_node->data = value;        /* 存入队列节点       */
  28.    new_node->next = NULL;         /* 设定初值           */
  29.    if ( rear == NULL )            /* 是否是第一次存入   */
  30.       front = new_node;           /* front指向new_node  */
  31.    else
  32.       rear->next = new_node;      /* 插入rear之后       */
  33.    rear = new_node;               /* rear指向new_node   */
  34. }
  35. /* ---------------------------------------- */
  36. /*  队列资料的取出                          */
  37. /* ---------------------------------------- */
  38. int dequeue()
  39. {
  40.    link top;
  41.    int temp;
  42.    if ( front != NULL )           /* 队列是否是空的     */
  43.    {
  44.       top = front;                /* top指向front       */
  45.       front = front->next;        /* 删除之前节点       */
  46.       temp = top->data;           /* 取出资料           */
  47.       free(top);                  /* 释回记忆体         */
  48.       return temp;                /* 队列取出           */
  49.    }
  50.    else
  51.       return -1;                  /* 无法取出           */
  52. }
  53. /* ---------------------------------------- */
  54. /*  主程式: 模拟队列操作                    */
  55. /*  输出输入的内容都会储存於数组中, 接着列  */
  56. /*  印出数组内容来看其结果.                 */
  57. /* ---------------------------------------- */
  58. void main()
  59. {
  60.    int input[100];                /* 储存输入的元素     */
  61.    int output[100];               /* 储存取出的元素     */
  62.    int select;                    /* 选择项1,2,或3      */
  63.    int i_count = 0;               /* 数组input的索引    */
  64.    int o_count = 0;               /* 数组output的索引   */
  65.    int loop = 1;                  /* 回路控制           */
  66.    int i,temp;
  67.    while ( loop )                 /* 主回路开始         */
  68.    {
  69.       /* 选项内容 */
  70.       printf("[1]输入 [2]取出 [3]列出全部内容 ==> ");
  71.       scanf("%d",&select);        /* 读入选项           */
  72.       switch ( select )
  73.       {
  74.          /* 输入值后将之存入队列 */
  75.          case 1: printf("请输入存入队列的值(%d) ==> ",
  76.                          i_count + 1);
  77.                  scanf("%d",&temp);
  78.                  if ( enqueue(temp) == -1 )
  79.                     printf("队列全满.n");
  80.                  else
  81.                     input[i_count++] = temp;
  82.                  break;
  83.          /* 取出队列的内容 */
  84.          case 2: if ( (temp = dequeue()) == -1 )
  85.                     printf("队列是空的.n");
  86.                  else
  87.                  {
  88.                     printf("取出队列元素: %dn",temp);
  89.                     output[o_count++] = temp;
  90.                  }
  91.                  break;
  92.          /* 离开回路 */
  93.          case 3: loop = 0;        /* 设定loop为零       */
  94.                  break;
  95.       }
  96.    }
  97.    printf("输入队列的元素: ");    /* 输出结果           */
  98.    for ( i = 0; i < i_count; i++ )    /* 列印回路       */
  99.       printf("[%d]",input[i]);
  100.    printf("n取出队列的元素: ");
  101.    for ( i = 0; i < o_count; i++ )    /* 列印回路       */
  102.       printf("[%d]",output[i]);
  103.    printf("n剩下队列的元素: ");
  104.    while ( (temp = dequeue()) != -1 ) /*取出剩下队列元素*/
  105.       printf("[%d]",temp);
  106.    printf("n");                      /* 换行           */
  107. }