第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。
此程序调用了环形队列算法库(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。
相关文章推荐
- 修改oracle的字符集
- Deep Learning(深度学习)学习笔记整理系列之(一)
- nginx模块使用自定义变量
- iOS开发001 深入学习:华丽的#define
- Java FileInputStream与FileReader的区别
- DWZ富客户端框架使用
- Android性能专项测试之Allocation Tracker(Android Studio)
- Hive SQL的编译过程
- Mac上,执行定时脚本:launchctl
- pyqt4中对话框模态和非模态
- 检测特殊字符的正则
- java.lang.OutOfMemoryError处理
- 成为高效程序员的搜索技巧
- 2015 10月15日 工作计划与执行
- HashMap实现原理
- appium滑动操作
- X86-64寄存器和栈帧
- 看不到 虚拟打印机 adobe pdf printer
- Ubuntu 下修改文件拥有者
- 磁盘扩容