| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1491 人关注过本帖
标题:链表的奇偶节点分离,为什么没有输出?
取消只看楼主 加入收藏
CJ17
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2020-7-31
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:1 
链表的奇偶节点分离,为什么没有输出?
link solve(link & L)
{
    int a=0;
    link p1,p2,p,L1,L2;
    L1=(node *)malloc(sizeof(node));
    L2=(node *)malloc(sizeof(node));  
    p1=L1->next=NULL;
    p2=L2->next=NULL;
    p=L->next;
    while(L!=NULL)
    {
        a++;
        if(a%2!=0)
        {
            p1=(node *)malloc(sizeof(node));
            p1->data=p->data;
            p1=p1->next;
        }
        else
        {
            p2=(node *)malloc(sizeof(node));
            p2->data=p->data;
            p2=p2->next;
        }
        p=p->next;
    }
    p1->next=L2->next;
    p2->next=NULL;
    return L1;
}
}
搜索更多相关主题的帖子: NULL data sizeof next node 
2021-03-22 17:24
CJ17
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2020-7-31
收藏
得分:0 
回复 2楼 apull
link solve(link & L)
{
    int i=0;
    link p=L,pa,pb,h=NULL,a,b;
    pa=(node *)malloc(sizeof(node));
    pb=(node *)malloc(sizeof(node));
    pa->next=h;
    pb->next=h;
    a=pa;
    b=pb;
    while(p->next!=NULL)
    {
        i++;
        if(i%2==0)
        {
            a->next=p;
            a=a->next;
        }
        else if(i%2!=0)
        {
            b->next=p;
            b=b->next;
        }
        p=p->next;
    }
    b->next=NULL;
    a->next=pb->next;
    return pa;

}
改成这样了,可是中间少输出一个元素,比如输入15 1 2 3 4 5 6 7 8 9 10 20 30 40 50 60,正确输出应该是1 3 5 7 9 20 40 60 2 4 6 8 10 30 50而我输出的是1 3 5 7 9 20 40 0 2 4 6 8 10 30 50,中间的60变成了0,这是怎么回事?
2021-03-23 12:36
快速回复:链表的奇偶节点分离,为什么没有输出?
数据加载中...
 
   



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

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