算法导论 10.2-3

题目:使用单链表实现队列,Enqueue与Dequeue操作时间为O(1)

代码

struct Node;
struct QueueRecord;
typedef struct Node * PtrToNode;
typedef struct QueueRecord * Queue;

struct Node
{
    ElementType Element;
    PtrToNode Next;
};

struct QueueRecord
{
    PtrToNode Front;
    PtrToNode Rear;
};

Queue CreateQueue( );
void DisposeQueue( Queue Q );
int IsEmpty( Queue Q );
void MakeEmpty( Queue Q );
void Enqueue( ElementType X, Queue Q );
void Dequeue( Queue Q );
ElementType Front( Queue Q );
ElementType FrontAndDequeue( Queue Q );

Queue CreateQueue()
{
    Queue Q;

    Q = (Queue) malloc( sizeof( struct QueueRecord ) );
    if ( NULL == Q )
    {
        printf( "Out of Space!!!" );
        return NULL;
    }

    // 链表栈中含有头结点
    Q->Front = Q->Rear = ( PtrToNode ) malloc( sizeof( struct QueueRecord ) );
    if ( Q->Front == NULL )
    {
        printf( "Out of space!!!" );
        return NULL;
    }

    Q->Front->Next = NULL;
    return Q;
}

void DisposeQueue( Queue Q )
{
    while( !IsEmpty(Q) )
        Dequeue( Q );

    free( Q->Front );
    free( Q );
}

void Enqueue( ElementType X, Queue Q )
{
    PtrToNode TmpCell;

    TmpCell = (PtrToNode) malloc( sizeof( struct Node ) );
    if ( TmpCell == NULL )
    {
        printf("Out of space!!!");
        return;
    }
    else
    {
        TmpCell->Element = X;
        TmpCell->Next = NULL;
        Q->Rear->Next = TmpCell;
        Q->Rear = TmpCell;
    }
}

void Dequeue( Queue Q )
{
    if ( IsEmpty(Q) )
    {
        printf( "Out of space!!!" );
        return;
    }
    else
    {
        PtrToNode TmpCell;

        TmpCell = Q->Front->Next;
        Q->Front->Next = TmpCell->Next;
        if ( Q->Rear == TmpCell )
            Q->Rear = Q->Front;
        free( TmpCell );
    }
}

int IsEmpty( Queue Q )
{
    return Q->Front->Next == NULL;
}

void MakeEmpty( Queue Q )
{
    if ( Q == NULL )
    {
        printf( "Must creat queue first!" );
        return;
    }
    
    while ( !IsEmpty(Q) )
        Dequeue( Q );
}

ElementType Front( Queue Q )
{
    if ( IsEmpty(Q) )
    {
        printf( "Empty Queue" );
        return 0;
    }
    else
        return Q->Front->Next->Element;
}

ElementType FrontAndDequeue( Queue Q )
{
    ElementType TmpCell;

    if ( IsEmpty(Q) )
    {
        printf( "Empty Queue" );
        return 0;        
    }
    else
    {
        TmpCell = Front( Q );
        Dequeue( Q );
        return TmpCell;
    }
}
原文地址:https://www.cnblogs.com/tallisHe/p/4033004.html