求大神,有关队列的问题,进队列的赋值时程序终止

 #include<iostream>
using namespace std;
class queue
{
private:
    int top, rear;
    int* data;
public:
    queue()
    {
        rear = top = 0;
        data = new int[100];
    }
    void in(queue* p, char value)
    {
        p->data[top] = value;
        top++;
    }
    void out(queue* p)
    {
        char temp;
        temp = p->data[rear];
        rear++;
    }
};
struct bitree
{
    char data;
    bitree* lchirld;
    bitree* rchirld;
};
void previsited(bitree* p)
{
    if (p)
    {
        cout << p->data;
        previsited(p->lchirld);
        previsited(p->rchirld);
    }
}
void precin(bitree*& s)
{
    char value;
    cin >> value;
    if (value != '#')
    {
        s = new bitree;
        s->data = value;
        s->lchirld = new bitree;
        s->rchirld = new bitree;
        precin(s->lchirld);
        precin(s->rchirld);
    }
    else
    {
        s = NULL;

    }
}
//层序遍历
void levelprint(queue*& p, bitree* q)
{
    if (q)
    {
        p->in(p, q->data);
        if (q->lchirld != NULL)
        {
            p->in(p, q->lchirld->data);
        }
        if (q->rchirld)
        {
            p->in(p, q->rchirld->data);
        }
        levelprint(p, q->lchirld);
        levelprint(p, q->rchirld);
    }
}
void main()
{
    bitree* bt;
    queue* q;
    precin(bt);
    levelprint(q, bt);
    cout << endl;
}

in()函数中的赋值p->data[top] = value;这一句出了问题,为什么?难道是没有开辟空间吗?构造函数不是自动执行吗?

Data is int
But value is char