#include
#include
#include
#define PRIMAX 100000 //非优先级模式下
typedef struct qnode
{
char data[10];
struct qnode *next;
int priority;//优先级,0的优先级最高,1次之,逐步优先级递减
} QNODE; /*链队结点类型*/
QNODE *front,*rear;
void InitQueue()
{
front=(QNODE *)malloc(sizeof(QNODE));
rear=front;
front->next=NULL;
front->priority = 0;//lzl add
}
void AddQueue(char x[], int prioty)
{
if (prioty<0)
{
printf("\nPriority is not right!\n");
return ;
}
QNODE *p=NULL;
p=(QNODE *)malloc(sizeof(QNODE));
if(p==NULL)
{
printf("内存不足");
exit(1);
}
strcpy(p->data, x);
p->next=NULL;
p->priority = prioty;
//lzl Modify begin
if (front == rear || prioty==PRIMAX)//空队列或非优先级模式
{
rear->next = p;
rear = p;
return ;
}
if (front!=rear && rear->priority <= prioty)
{
rear->next = p;
rear = p;
}
else
{
if (p->prioritynext->priority)
{
p->next = front->next;
front->next = p;
}
else
{
QNODE *temp = front;
while (temp != NULL && (temp->priority)>=(p->priority))
{
//实际上temp值是不会等于NULL
//因为前面已对尾部节点的优先级做判断
temp = temp->next;
}
p->next = temp->next;
temp->next = p;
}
}
//lzl Modify end
}
void HeadAddQueue(char x[])
{ //在队头插入
}
int DelQueue(char x[])
{
QNODE *p;
if (front==rear)
return 0; //队空
p=front->next;
strcpy(x, p->data);
front->next=p->next;
if (p->next==NULL) //最后一个元素出队
rear=front;
free(p);
return 1;
}
int QueueEmpty()
{
if(front==rear)
return 1; //队空
else
return 0;
}
void DispQueue(int iAll)
{
QNODE *p=front->next;
int i=1;
printf("\n");
if (iAll==1)//输出队列中全部名称
{
while (p!=NULL)
{
printf("第%d位 名字%s\n",i,p->data);
p=p->next;
i++;
}
printf("\n");
}
else//单个客户查找
{
char cName[10]={0};
printf("\n用户名:");
scanf("%s",cName);
while (p!=NULL && strcmp(p->data,cName)!=0 )
{
p = p->next;
i++;
}
if (p == NULL)
{
printf("\n没有找到该客户");
}
else
{
printf("\n客户信息:第%d位 名字%s",i,p->data);
}
}
}
void main()
{
char sel;
char name[10];
int priority=0;
char ch;
InitQueue(); //初始化队
while (1)
{
printf("\n\t\t\t 1:进入排队");
printf("\n\t\t\t 2:办理业务");
printf("\n\t\t\t 3:查看个体");
printf("\n\t\t\t 4:查看全部");
printf("\n\t\t\t 0:下班");
printf("\n请选择:");
//_flushall();
fflush(stdin);
scanf("%c",&sel);
switch(sel)
{
case '0':
if (!QueueEmpty()) //队不空
printf("请排队的客户明天再来\n");
return;
case '1':
printf("输入客户姓名: ");
scanf("%s",name);
_flushall();
printf("是否优先?(y/n):");
scanf("%c",&ch);
if (ch=='Y'||ch=='y')
{
//读入优先级
printf("优先级:");
scanf("%d",&priority);
AddQueue(name,priority); //入队
}
else
{
AddQueue(name,PRIMAX);
}
break;
case '2':
if (!DelQueue(name)) //出队
printf("没有排队的客户\n");
else
printf("请客户%s办理\n",name);
break;
case '3':
case '4':
if (QueueEmpty()) //队空
printf("没有排队的客户\n");
else
{
printf("排队者:");
//sel-'3'值为0表示单个客户查询,值为1表示查询全部
DispQueue(sel-'3');
}
break;
default:
printf("选择错误,请重新选择。\n");
break;
}
}
}