| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 391 人关注过本帖
标题:不加销毁函数能出结果,加上结果就不对!求高手指点
只看楼主 加入收藏
天涯花落
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-6-13
结帖率:0
收藏
已结贴  问题点数:5 回复次数:1 
不加销毁函数能出结果,加上结果就不对!求高手指点
#include<iostream>
using namespace std;
#include<cstdlib>
#define OK 1
#define ERROW 0
#define OVERFLOW 0
typedef struct QNode
{
    int data;
    struct QNode*next;
}QNode,*QueuePtr;
typedef struct
{
    QueuePtr front;
    QueuePtr rear;
}LinkQueue;
int InitQueue(LinkQueue &Q)//构造一个空对
{
    Q.front=(QNode*)malloc(sizeof(QNode));
    if(!Q.front)exit(OVERFLOW);
    Q.rear=Q.front;
    Q.front->next=NULL;   
    return OK;
}
int QueueEmpty(LinkQueue &Q)
{
    if(Q.front==Q.rear)
        return ERROW;
    else
        return OK;
}
int EnQueue(LinkQueue &Q,int e)//入对
{
  QueuePtr p;
  p=(QNode*)malloc(sizeof(QNode));
  if(!p)exit(OVERFLOW);
  p->next=NULL;
  p->data=e;
  Q.rear->next=p;
  Q.rear=p;
return OK;
}
int DeQueue(LinkQueue &Q,int &e)//出队
{
    QueuePtr p;   //为什么把它改为 LNode *p就对了啊 想了很长时间想不明白  或者把 DestroyQueue函数去掉也对!
    p=Q.front->next;
    e=p->data;
    Q.front->next=p->next; //求指点!!!谢谢了!!!
    if(Q.rear==p)
        Q.front=Q.rear;
    free(p);
    return ok;
}
int DestroyQueue(LinkQueue &Q)
{
    while(Q.front)
    {
        Q.rear=Q.front->next;
        free(Q.front);
        Q.front=Q.rear;
    }
    cout<<"队列已被销毁."<<endl;
    return OK;
}
int main()
{
    LinkQueue Q;
    InitQueue(Q);
    int n;
    cout<<"请输入要处理数的个数:";
    cin>>n;
    int i=0,e;
    while(i<n)
    {
      cout<<"请输入第"<<i+1<<"个数:";
      cin>>e;
      EnQueue(Q,e);
      i++;
    }
    i=0;
    while(i<n)
    {
      DeQueue(Q,e);
      cout<<e<<"  ";
      i++;
    }
    cout<<endl;
    DestroyQueue(Q);//加上它就不对了!
    return 0;
}
搜索更多相关主题的帖子: include return 
2013-10-28 23:04
yuccn
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:何方
等 级:版主
威 望:167
帖 子:6814
专家分:42393
注 册:2010-12-16
收藏
得分:5 
int DeQueue(LinkQueue &Q,int &e)//出队
{
    QueuePtr p;   //为什么把它改为 LNode *p就对了啊 想了很长时间想不明白  或者把 DestroyQueue函数去掉也对!
    p=Q.front->next;
    e=p->data;

如果Q.front->next 为NULL 不久崩溃了?

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-10-29 13:40
快速回复:不加销毁函数能出结果,加上结果就不对!求高手指点
数据加载中...
 
   



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

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