| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 532 人关注过本帖
标题:为什么空链表不能插入
只看楼主 加入收藏
fdgfdfdh
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2013-5-7
结帖率:71.43%
收藏
已结贴  问题点数:20 回复次数:5 
为什么空链表不能插入
#include<stdio.h>
#include<malloc.h>
void *insret(struct aaa **head,struct aaa *p0);
void print(struct aaa *p);
#define LEN sizeof(struct aaa)
#define NULL 0
struct aaa
{
    int num;
    struct aaa *next;
};
void main()
{
    struct aaa *p1,*p2,*head,*p0;
    int n=0;
    p1=p2=(struct aaa *)malloc(LEN);
    head=NULL;
    scanf("%d",&p1->num);
    while(p1->num!=0)
    {
        n++;
        if(n==1)
            head=p1;
        else p2->next=p1;
        p2=p1;
        p1=(struct aaa *)malloc(LEN);
        scanf("%d",&p1->num);
    }
    p2->next=NULL;
    p0=(struct aaa *)malloc(LEN);
    printf("please p0");
    scanf("%d",&p0->num);

    insret(&head,p0);
    print(head);
    }
void *insret(struct aaa **head,struct aaa *p0)
{
    struct aaa *p1,*p2;
    p1=*head;
    if(head==NULL)
    {
        *head=p0;
        p0->next=NULL;
    }
    else
        while((p0->num > p1->num) && (p1->next!=NULL))
        {
            p2=p1;
            p1=p1->next;
        }
        if(p1->num >= p0->num)
        {
            if(*head==p1)
                *head=p0;
            else p2->next=p0;
            p0->next=p1;
        }
        else
        {
            p1->next=p0;
            p0->next=NULL;
        }
        return head;
}
void print(struct aaa *p)
{
    struct aaa *r;
    int k=0;
    r=p;
    while(r!=NULL)
    {
        k++;
        printf("%d  %d\n",k,r->num);
        r=r->next;
    }
}
搜索更多相关主题的帖子: void next include 
2013-05-08 13:59
wwfdzh2012
Rank: 2
等 级:论坛游民
帖 子:88
专家分:27
注 册:2012-11-22
收藏
得分:0 
楼主弄一个链表都要用双重指针。。。把简单问题复杂化了
2013-05-08 16:41
yyqd2013
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:35
专家分:154
注 册:2013-5-8
收藏
得分:0 
void *insret(struct aaa **head,struct aaa *p0)
{
    struct aaa *p1,*p2;
    p1=*head;
    if(head==NULL)
    {
        *head=p0;
        p0->next=NULL;
        return;
    }
    else
   {
        while((p0->num > p1->num) && (p1->next!=NULL))
        {
            p2=p1;
            p1=p1->next;
        }
        if(p1->num >= p0->num)
        {
            if(*head==p1)
                *head=p0;
            else p2->next=p0;
            p0->next=p1;
        }
        else
        {
            p1->next=p0;
            p0->next=NULL;
        }
        return head;
    }
}
2013-05-08 17:09
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:20 
我先说句,你这样真的小题大做了,太麻烦了,我运行的可以插入呢?你看看;
#include<stdio.h>
#include<malloc.h>
void *insret(struct aaa **head,struct aaa *p0);
void print(struct aaa *p);
#define LEN sizeof(struct aaa)
#define NULL 0
struct aaa
{
    int num;
    struct aaa *next;
};
void main()
{
    struct aaa *p1,*p2,*head,*p0;
    int n=0;
    p1=p2=(struct aaa *)malloc(LEN);
    head=NULL;
    scanf("%d",&p1->num);
    while(p1->num!=0)
    {
        n++;
        if(n==1)
            head=p1;
        else p2->next=p1;
        p2=p1;
        p1=(struct aaa *)malloc(LEN);
        scanf("%d",&p1->num);
    }
    p2->next=NULL;
    p0=(struct aaa *)malloc(LEN);
    printf("please p0");
    scanf("%d",&p0->num);

    insret(&head,p0);
    print(head);
    }
void *insret(struct aaa **head,struct aaa *p0)
{
    struct aaa *p1,*p2;
    p1=*head;
    if(head==NULL)
    {
        *head=p0;
        p0->next=NULL;
    }
    else
        while((p0->num > p1->num) && (p1->next!=NULL))
        {
            p2=p1;
            p1=p1->next;
        }
        if(p1->num >= p0->num)
        {
            if(*head==p1)
                *head=p0;
            else p2->next=p0;
            p0->next=p1;
        }
        else
        {
            p1->next=p0;
            p0->next=NULL;
        }
        return head;
   
}
void print(struct aaa *p)
{
    struct aaa *r;
    int k=0;
    r=p;
    while(r!=NULL)
    {
        k++;
        printf("%d  %d\n",k,r->num);
        r=r->next;
    }
}

Maybe
2013-05-08 19:58
fdgfdfdh
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2013-5-7
收藏
得分:0 
回复 4楼 邓士林
多谢您抽时间帮忙,小弟是新手,还处于练习阶段,不晓得如何简单,还请赐教
2013-05-09 09:09
fdgfdfdh
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2013-5-7
收藏
得分:0 
回复 3楼 yyqd2013
多谢您抽时间回复,能否交个朋友 我QQ316928512
2013-05-09 09:17
快速回复:为什么空链表不能插入
数据加载中...
 
   



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

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