标题:求助!!在链表中删除结点!!
取消只看楼主
雨汪
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2013-8-2
结帖率:100%
已结贴  问题点数:14 回复次数:2 
求助!!在链表中删除结点!!
#include<stdio.h>
#include<stdlib.h>
#define LEN sizeof(struct stu)
struct stu
{
    int num;
    double score;
    struct stu *next;
};
struct stu *del(struct stu *head,int num)
{
    struct stu *p0;/*指向要删除的结点*/
    struct stu *p1;/*p1的next域指向p0*/
    p0=head;
    if(head==NULL)
        printf("The list is null\n");
    else
    {
        while(p0!=NULL&&p0->num!=num)
        {
            p1=p0;
            p0=p0->next;/*p0向后移位*/
        }
        if(p0->num==num) /*找到了删除的结点*/
        {
            if(head==p0) /*要删除的结点为第一个结点*/
                head=p0->next;
            else
            {
                p1->next=p0->next;/*p1的next域指向p0的next域*/
                free(p0);/*释放p0的内存空间*/
            }
        }
        else
            printf("%d not been found!\n",num);/*没找到要删除的结点*/
    }
    return head;
}
struct stu *list(struct stu *head,struct stu *news)
{
    struct stu *p0;/*指向要插入的结点*/
    struct stu *p1;/*指向第一个学号比p0指向的结点学号大的结点*/
    struct stu *p2;/*p2的next域指向p1*/
    p1=head;
    p0=news;
    if(head==NULL)/*链表为空*/
    {
        head=p0;
        p0->next=NULL;
    }
    else
    {
        while((p1!=NULL)&&(p0->num>=p1->num))/*寻找第一个学号比插入结点学号大的结点*/
        {
            p2=p1;
            p1=p1->next;
        }
        if(p1==NULL) /*没找到比插入结点学号大的结点*/
        {
            p1->next=p0;
            p0->next=NULL;
        }
        else
        {
            if(head==p1) head=p0;/*找到的结点为链表的第一个结点*/
            else
            {
                p2->next=p0;
                p0->next=p1;
            }
        }
    }
    return head;
}
void output(struct stu *head)
{
    struct stu *p;
    p=head;
    if(head==NULL)
        printf("The list is a null\n");
    else
    {
        while(p!=NULL)
        {
            printf("%d %5.1f\n",p->num,p->score);
            p=p->next;
        }
    }
}

int main()
{
    struct stu *head;
    struct stu *news;
    int num;
    head=NULL;
    scanf("%d",&num);
    while(num!=0)/*输入链表中的数据,输入为零结束*/
    {
        news=(struct stu *)malloc(LEN);/*为指针分配内存空间*/
        news->num=num;
        scanf("%f",&news->score);
        head=list(head,news);
        scanf("%d",&num);
    }
    output(head);
    printf("input the number for deletion:");
    scanf("%d",&num);
    printf("delete:%d\n",num);
    head=del(head,num);
    output(head);
    return 0;
}
没有错误,没有警告,但是运行时一直出错!!代码有点长,辛苦各位了!劳驾各位高手给个正解,谢谢哈!!

[ 本帖最后由 雨汪 于 2013-8-4 12:11 编辑 ]
搜索更多相关主题的帖子: include double null 
2013-08-04 12:10
雨汪
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2013-8-2
得分:0 
回复 2楼 peach5460
拜托,我调试了好吧!!只是一直通不过,我研究了一个上午了愣是没找着问题出在哪了,所以才放在这上面想让大家帮忙看看,你不想帮忙就算了,用得着这么说吗??
2013-08-04 14:57
雨汪
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2013-8-2
得分:0 
回复 4楼 ppfly
哈哈,果然可以!!看来问题出在了这段代码上了啊!真心感谢哈!!有了你的提示,我想应该可以把原来错误的地方找出来了!!
2013-08-04 16:47



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-418583-1-1.html




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

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