5_11.C
上传用户:wyn840322
上传日期:2007-01-13
资源大小:294k
文件大小:4k
- /* ======================================== */
- /* 程式实例: 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("取出队列元素: %dn",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"); /* 换行 */
- }