| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 669 人关注过本帖
标题:大家看看我这是不是标准循环队列!
只看楼主 加入收藏
未来的梦
Rank: 1
等 级:新手上路
帖 子:31
专家分:0
注 册:2006-3-23
收藏
 问题点数:0 回复次数:2 
大家看看我这是不是标准循环队列!

//循环队列程序
#include<stdio.h>
#include<stdlib.h>
#define INIT_QUEUE_SIZE 100
typedef struct{
int *base;
int front;
int rear;
}SqQueue;

SqQueue InitQueue(SqQueue Q);
SqQueue EnQueue(SqQueue Q,int value);
void TraverseQueue(SqQueue Q);

int main(void)
{
SqQueue Q;
int value,i,n;

Q=InitQueue(Q);
printf("Please input element number: ");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
scanf("%d",&value);
Q=EnQueue(Q,value);
}
TraverseQueue(Q);
free(Q.base);

return 0;
}

SqQueue InitQueue(SqQueue Q)
{
if((Q.base=(int *)malloc(INIT_QUEUE_SIZE * sizeof(int)))==NULL)
{
exit(1);
}
Q.front=0;
Q.rear=0;

return Q;
}

SqQueue EnQueue(SqQueue Q,int value)
{
if((Q.rear+1)%INIT_QUEUE_SIZE == Q.front) //队列满
{
exit(1);
}
Q.base[Q.rear]=value;
Q.rear=(Q.rear+1)%INIT_QUEUE_SIZE; //确定队尾指针的位置

return Q;
}

void TraverseQueue(SqQueue Q)
{
while(Q.front != Q.rear)
{
printf("%d->",Q.base[Q.front++]);
}
printf("null\n");
}

搜索更多相关主题的帖子: 队列 int SqQueue value 
2006-03-26 18:56
踏魔狼
Rank: 6Rank: 6
等 级:贵宾
威 望:24
帖 子:1322
专家分:33
注 册:2005-9-22
收藏
得分:0 

=×&D o I p R e E n C g T l X&×=
2006-03-26 19:33
success
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-3-24
收藏
得分:0 
前面没问题,void TraverseQueue(SqQueue Q)函数有问题,
确定下一个元素的方法不对,再看看,不难

2006-03-27 13:25
快速回复:大家看看我这是不是标准循环队列!
数据加载中...
 
   



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

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