您的位置:首页 > 其它

第7周 项目3 - 负数把正数赶出队列

2015-10-15 16:41 211 查看
问题及代码:

此程序调用了环形队列算法库(sqqueue.cpp和sqqueue.h)。

/*
*Copyright(c) 2015,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:test.cpp
*作 者:徐群壮
*完成日期:2015.10.15
*版 本 号:v1.0
*
*问题描述:设从键盘输入一整数序列a1,a2,…an,试编程实现:当ai>0时,ai进队,
当ai<0时,将队首元素出队,当ai=0时,表示输入结束。要求将队列处理成环形队列,
使用算法库中定义的数据类型及算法,程序中只包括一个函数(main函数),入队和
出队等操作直接写在main函数中即可。当进队出队异常(如队满)时,要打印出错信息。
并且在最后输出队列信息。
*输入描述:
*程序输出:
*/
#include <iostream>
#include <malloc.h>
#include "sqqueue.h"
using namespace std;
void printfQueue(SqQueue *q)
{
SqQueue *temp=q;
cout<<"队列为:"<<endl;
while(temp->front!=temp->rear)
{
temp->front=(temp->front+1)%MaxSize;
cout<<temp->data[temp->front]<<' ';
}
}
int main()
{
ElemType a,x;
SqQueue *qu;
InitQueue(qu);
while(1)
{
cout<<"输入a值(输入正数进队,负数出队,0结束)"<<endl;
cin>>a;
if(a>0)
{
if(!enQueue(qu,a))
cout<<"队列满,不能入列。"<<endl;
}
else if(a<0)
{
if(!deQueue(qu,x))
cout<<"队列空,不能出队。"<<endl;
}
else
break;
}
printfQueue(qu);
return 0;
}


运行结果:



知识点总结及学习心得:

⒈在一开始直接调用算法库的时候会出现乱码,原因是我们在主程序中的判断依据是看输入数的正负,当初编写sqqueue的算法库的时候。设置了ElemType为char类型。所以在具体的实践过程中。要根据实际情况修改算法库中的数据。

⒉在当初写算法库的时候。设置的MaxSize为5.根据程序可以看出。我们实际存入的只有4(MaxSize)个元素。这是因为我们在当初区分队满和队空的时候,约定在进队时少用一个数据元素空间。所以队列中始终一个空元素不用。这点是我们在编程中所需要注意的。

⒊在定义输出队元素的函数的时候。一开始我并没有在此函数中定义与q指针相同的temp指针。但是后来我发现。如果不用temp指针(记录下q的位置),在循环结束后原先的front指针和rear所指向的内容已经变化。如果此程序后面没有操作还好说、万一又有进队或者出队的操作就错了。所以我在这定义了temp指针,记录q。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: