| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 374 人关注过本帖
标题:一大堆错误,帮我改改
取消只看楼主 加入收藏
mike_ge
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-5-8
结帖率:0
收藏
已结贴  问题点数:10 回复次数:0 
一大堆错误,帮我改改
带头结点的循环链表表示队列 只设一个队尾指针,写置空,判队空,入队,出队,初始化队

#include <stdio.h>
#include<stdio.h>
#include<malloc.h>

typedef struct node{
        int data;
    struct node *next;
}Linklist;

typedef struct{
    Linklist *rear;
}LinkQ;

LinkQ *SetQueue(){
    LinkQ *Q;
    Q=(LinkQ *)malloc(sizeof(LinkQ));
    Q->rear->next=Q->rear;
    return Q;
}

int EmptyQueue(LinkQ *Q){
    if(!Q->rear)
        return 1;
    else
        return 0;
}

LinkQ *Add(LinkQ *Q,int x){
    LinkQ *p;
    p=(LinkQ *)malloc(sizeof(LinkQ));
    p->rear->data=x;
    p->next=Q->rear->next;
    Q->rear->next=p;
    Q->rear=p;
    return Q;
}

LinkQ *Delete(LinkQ *Q){
    LinkQ *p;
    if(!EmptyQueue){
        p=Q->rear->next;
        Q->rear->next=p->next;
        free(p);
    }
    return Q;
}

LinkQ InitQueue(LinkQ *Q){
    Q->rear=Q->rear->next;
    return Q;
}

void main(){
    int n,choice;
    LinkQ *S;
    do{
    printf("1.建空队\n");
    printf("2.判空队\n");
    printf("3.入队\n");
    printf("4.出队\n");
    printf("5.置空队\n");
    printf("6.退出\n");
    printf("请选择:");
    scanf("%d",&choice);
    switch(choice){
    case 1:SetQueue(); break;
    case 2:EmptyQueue(S);break;
    case 3:printf("输入元素,以-1结束:");
        scanf("%d",&n);
        while(n!=-1){
        Add(S,n);
        scanf("%d",&n);
        };break;
    case 4:Delete(S);break;
    case 5:InitQueue(S);break;
    }
    }while(choice!=6);
}






搜索更多相关主题的帖子: return 
2011-05-08 23:15
快速回复:一大堆错误,帮我改改
数据加载中...
 
   



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

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