标题:队列的顺序存储结构及实现
取消只看楼主
bmw750love
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2007-11-2
 问题点数:0 回复次数:1 
队列的顺序存储结构及实现
//队列的顺序存储结构及实现
#include"stdio.h"
#include"stdlib.h"
#define MAXSIZE 100
typedef int ElemType;
typedef struct
{ElemType elem[MAXSIZE];
int front,rear;
}SeQueue;
void creat(SeQueue *Q);
void AddQ(SeQueue *Q,ElemType x);
ElemType Del(SeQueue *Q);
void outlin(SeQueue Q);
void main()
{
SeQueue se;ElemType x,y;int cord;
do
{ printf("\n 主菜单 \n");
printf("\n 1 建立顺序队列 \n");
printf("\n 2 入队一个元素 \n");
printf("\n 3 删除一个元素 \n");
printf("\n 4 结束程序运行 \n");
printf("--------------------\n");
printf("请输入您的选择(1,2,3,4)");scanf("%d",&cord);
switch(cord)
{case 1:{creat(&se);outlin(se);
}break;
case 2:{printf("\n x=");scanf("%d",&x);
AddQ(&se,x);
outlin(se);
}break;

case 3:{y=Del(&se);printf("\n x=%d",y);
outlin(se);
}break;
case 4:exit(0);
}
}while(cord<=4);
}
void creat(SeQueue *Q)
{int i,n,x;
Q->front=-1;
Q->rear=-1;
printf("n= ");scanf("%d",&n);
for(i=1;i<=n;i++)
{printf("\n data= ");scanf("%d",&x);
AddQ(Q,x);
}
}
void AddQ(SeQueue *Q,ElemType x)
{if((Q->rear+1)%MAXSIZE==Q->front)printf("Queue is FULL!\n");
else{Q->rear=(Q->rear+1)%MAXSIZE;
Q->elem[Q->rear]=x;
}
}
ElemType Del(SeQueue *Q)
{if(Q->front==Q->rear)
{printf("Queue is EMPTY!\n");
return -1;
}
else {Q->front=(Q->front+1)%MAXSIZE;
return(Q->elem[Q->front]);
}
}
void outlin(SeQueue Q)
{int i;
if(Q.front==Q.rear)printf("\n Queue is EMPTY!\n");
else
{printf("\n队列如下:");
for(i=Q.rear;i>=0;i--)
printf("\n%6d",Q.elem[i]);}
}
搜索更多相关主题的帖子: 队列 顺序 结构 
2007-11-04 17:17
bmw750love
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2007-11-2
得分:0 
2007-11-04 17:18



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-183439-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.169819 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved