标题:链表的奇偶节点分离,为什么没有输出?
只看楼主
CJ17
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2020-7-31
结帖率:100%
已结贴  问题点数:20 回复次数:3 
链表的奇偶节点分离,为什么没有输出?
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
apull
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:三体星系
等 级:版主
威 望:185
帖 子:1404
专家分:8479
注 册:2010-3-16
得分:10 
while(L!=NULL)
L没变化
2021-03-22 22:11
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
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:10 
第一,代码不全。这属于人品问题了
第二,link solve(link & L) 这是C代码还是C++代码?
第三,为什么“输入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”,第一个数 15 哪里去了?

程序代码:
#include <stdio.h>
#include <stdlib.h>

typedef struct node {
    int value;
    struct node* next;
} *link;

link fuck( const int arr[], size_t n )
{
    link head = NULL;

    link* last = &head;
    for( size_t i=0; i!=n; ++i )
    {
        (*last) = malloc( sizeof(struct node) );
        (*last)->value = arr[i];
        last = &(*last)->next;
    }
    *last = NULL;

    return head;
}

void shit( const link L )
{
    for( link p=L; p; p=p->next )
        printf( "%d%c", p->value, " \n"[p->next==NULL] );
}

int main( void )
{
    int arr[] = { 15, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 20, 30, 40, 50, 60 };
    link L = fuck( arr, sizeof(arr)/sizeof(*arr) );
    shit( L );

    extern link solve( link L );
    solve( L );
    shit( L );
}

link solve( link L )
{
    link a_head=NULL, *a_last=&a_head;
    link b_head=NULL, *b_last=&b_head;

    size_t index = 0;
    for( link p=L; p; p=p->next, ++index )
    {
        if( index%2 == 0 )
        {
            *a_last = p;
            a_last = &(*a_last)->next;
        }
        else
        {
            *b_last = p;
            b_last = &(*b_last)->next;
        }
    }

    *a_last = b_head;
    *b_last = NULL;
    return L;
}
2021-03-23 13:58



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




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

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