| 网站首页 | 业界新闻 | 群组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 编程论坛
共有 1979 人关注过本帖, 1 人收藏
标题:用队列实现层序遍历出现的问题
只看楼主 加入收藏
firewater
Rank: 1
等 级:新手上路
帖 子:47
专家分:4
注 册:2014-7-13
结帖率:87.5%
  已结贴   问题点数:20  回复次数:1   
用队列实现层序遍历出现的问题
建立队列的头节点那一段每次都显示:warning C4700: 使用了未初始化的局部变量“q”  

程序代码:
#include <stdio.h>
#include <stdlib.h>
//二叉树的节点

typedef int Status;
typedef char TElementType;
typedef struct BiTrNode
{
    TElementType data;
    struct BiTrNode *lchild;
    struct BiTrNode *rchild;
}BiTrNode, *BiTree;

//队列的节点
typedef BiTree QElementType;
typedef struct QueueNode
{
    QElementType data;
    struct QueueNode *next;
}QNode;
typedef struct LinkQueue
{
    QNode *front;
    QNode *rear;
}*Queue;

//建立队列的头节点

Queue CreateQueue(void)     //这里总是显示用了未初始化的局部变量“q”,但是我声明了啊
{
    Queue q;
    q->front = (QNode *)malloc(sizeof(QNode));
    q->rear = q->front;
    q->front->next = NULL;
    return q;
}
//入队操作

void Add(Queue Q, QElementType data)
{
    QNode *p = (QNode *)malloc(sizeof(QNode));
    p->data = data;
    p->next = NULL;
    Q->rear->next = p;
    Q->rear = p;
}
//出队操作
QElementType Delete(Queue Q)
{
    QElementType data;
    QNode *temp = Q->front->next;
    data = temp->data;
    Q->front->next = temp->next;
    free(temp);
    return data;

}
//判断队列是否为空
Status IsEmpty(Queue Q)
{
    return Q->front->next == NULL;
}
void CreateBiTree(BiTree *T)  //先序遍历生成二叉树

{
    char c;
    scanf("%c", &c);
    if (c == '#')
    {
        *T = NULL;
        return;
    }
    *T = (BiTree)malloc(sizeof(BiTrNode));
    (*T)->data = c;
    CreateBiTree(&((*T)->lchild));
    CreateBiTree(&((*T)->rchild));
}

void LevelOrderTraversal(BiTree T)
{
    Queue Q;
    if (T == NULL)
    {
        return;
    }
    Q = CreateQueue();
    Add(Q, T);
    while (!IsEmpty(Q))
    {
        T = Delete(Q);
        printf("%c", T->data);
        if (T->lchild)
        {
            Add(Q, T->lchild);
        }
        if (T->rchild)
        {
            Add(Q, T->rchild);
        }
    }
}

int main(void)
{
    BiTree T;
    CreateBiTree(&T);
    LevelOrderTraversal(T);
    return 0;
}

搜索更多相关主题的帖子: warning  
2015-11-28 17:31
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
  得分:20 
int *p;
*p = 5;


和这个代码的问题挺像的


[fly]存在即是合理[/fly]
2015-11-30 10:03







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

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