标题:两单循环链表合并代码跑不了 求助
只看楼主
飓风Cc
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2017-3-28
 问题点数:0 回复次数:1 
两单循环链表合并代码跑不了 求助
#include <stdio.h>
#include <stdlib.h>


typedef int ElemType;


typedef struct LNode{
    ElemType data;
    struct LNode   *next;
    }LNode,*LinkList;//定义结点


void CreateList(LinkList L,int n)
{
    L=(LinkList)malloc(sizeof(LNode));
    L->next=L;//空的单循环链表
    int i;
    for(i=1;i<=n;i++){
       LNode *p=(LinkList)malloc(sizeof(LNode));
        scanf("%d",&p->data);
        p->next=L->next;
        L->next=p;
    }//赋值
}//倒着输入


int main()
{
    int m,n;
    m=5;
    n=4;
    LNode *p,*q;
    LinkList L1,L2,L;
    CreateList( L1, m);
    CreateList(L2, n);
    if(m<=n){
        p=L2->next;
        q=L1->next;
        L2->next=q;
        while(q->next!=L1){
            q=q->next;
        }
        q->next=p;
        free(L1);
        L=L2;
    }
    else {
        p=L1->next;
        q=L2->next;
        L1->next=q;
        while(q->next!=L2){
            q=q->next;
        }
        q->next=p;
        free(L2);
        L=L1;

    }
    p=L->next;
    while(p->next!=L){
        printf("%d \n",p->data);
    }
    return 1;


}//将小的单循环链表拆开合并到大的链表中去
在codeblocks 上没发现问题 但是运行就出问题了,求指导该,谢谢
搜索更多相关主题的帖子: include 单循环 
2017-03-28 13:21
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
得分:0 
如下代码可行:

#include <stdio.h>
#include <stdlib.h>


typedef int ElemType;


typedef struct LNode{
    ElemType data;
    struct LNode   *next;
    }LNode,*LinkList;//定义结点


void CreateList(LinkList &L,int n)
{
    L=(LinkList)malloc(sizeof(LNode));
    L->next=L;//空的单循环链表
    int i;
    for(i=1;i<=n;i++){
       LNode *p=(LinkList)malloc(sizeof(LNode));
        scanf("%d",&p->data);
        p->next=L->next;
        L->next=p;
    }//赋值
}//倒着输入


int main()
{
    int m,n;
    m=5;
    n=4;
    LNode *p,*q;
    LinkList L1,L2,L;
    CreateList( L1, m);
    CreateList(L2, n);
    if(m<=n){
        p=L2->next;
        q=L1->next;
        L2->next=q;
        while(q->next!=L1){
            q=q->next;
        }
        q->next=p;
        free(L1);
        L=L2;
    }
    else {
        p=L1->next;
        q=L2->next;
        L1->next=q;
        while(q->next!=L2){
            q=q->next;
        }
        q->next=p;
        free(L2);
        L=L1;

    }
    p=L;
    do{
        p=p->next;
        printf("%d \n",p->data);
    }while(p->next!=L);
    return 1;


}
2017-03-28 15:02



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




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

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