⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 5_11.c

📁 从网上搜集的一些数据结构源码
💻 C
字号:
/* ======================================== */
/*    程式实例: 5_11.c                      */
/*    使用数组来构建环状队列                */
/* ======================================== */
#define MAXQUEUE 10               /* 队列的最大容量      */

int queue[MAXQUEUE];              /* 队列的数组宣告      */
int front = -1;                   /* 队列的前端          */
int rear = -1;                    /* 队列的后端          */

/* ---------------------------------------- */
/*  队列资料的存入                          */
/* ---------------------------------------- */
int enqueue(int value)
{
   if ( rear + 1 == front ||      /* 检查队列是否全满    */
        (rear == (MAXQUEUE - 1) && front <= 0) )
      return -1;                  /* 无法存入            */
   rear++;                        /* 后端指标往前移      */
   if ( rear == MAXQUEUE )        /* 是否超过界限        */
      rear = 0;                   /* 从头开始            */
   queue[rear] = value;           /* 存入队列            */
}

/* ---------------------------------------- */
/*  队列资料的取出                          */
/* ---------------------------------------- */
int dequeue()
{
   if ( front  == rear )          /* 检查队列是否是空    */
      return -1;                  /* 无法取出            */
   front++;                       /* 前端指标往前移      */
   if ( front == MAXQUEUE )       /* 是否超过界限        */
      front = 0;                  /* 从头开始            */
   return queue[front];           /* 队列取出            */
}

/* ---------------------------------------- */
/*  主程式: 模拟队列操作                    */
/*  输出输入的内容都会储存於数组中, 接着列  */
/*  印出数组内容来看其结果.                 */
/* ---------------------------------------- */
void main()
{
   int input[100];                /* 储存输入的元素      */
   int output[100];               /* 储存取出的元素      */
   int select;                    /* 选择项1,2,或3       */
   int i_count = 0;               /* 数组input的索引     */
   int o_count = 0;               /* 数组output的索引    */
   int loop = 1;                  /* 回路控制            */
   int i,temp;                    
   while ( loop )                 /* 主回路开始          */
   {
      /* 选项内容 */
      printf("[1]输入 [2]取出 [3]列出全部内容 ==> ");
      scanf("%d",&select);        /* 读入选项            */
      switch ( select )
      {
         /* 输入值后将之存入队列 */
         case 1: printf("请输入存入队列的值(%d) ==> ",
                         i_count + 1);
                 scanf("%d",&temp);
                 if ( enqueue(temp) == -1 )
                    printf("队列全满.\n");
                 else
                    input[i_count++] = temp;
                 break;
         /* 取出队列的内容 */
         case 2: if ( (temp = dequeue()) == -1 )
                    printf("队列是空的.\n");
                 else
                 {
                    printf("取出队列元素: %d\n",temp);
                    output[o_count++] = temp;
                 }
                 break;
         /* 离开回路 */
         case 3: loop = 0;        /* 设定loop为零        */
                 break;
      }
   }
   printf("输入队列的元素: ");    /* 输出结果            */
   for ( i = 0; i < i_count; i++ )     /* 列印回路       */
      printf("[%d]",input[i]);
   printf("\n取出队列的元素: ");
   for ( i = 0; i < o_count; i++ )     /* 列印回路       */
      printf("[%d]",output[i]);
   printf("\n剩下队列的元素: ");
   while ( (temp = dequeue()) != -1 )  /*取出剩下队列元素*/
      printf("[%d]",temp);
   printf("\n");                       /* 换行           */
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -