标题:不能成功调用函数
只看楼主
hcanhong
Rank: 1
来 自:肇庆学院网络工程系
等 级:新手上路
帖 子:58
专家分:0
注 册:2008-9-6
 问题点数:0 回复次数:2 
不能成功调用函数
#include <stdio.h>
#include <stdlib.h>

#define LEN sizeof(LNode)
#define OVERFLOW 0
#define OK 1

typedef struct LNode {
    int data;
    struct LNode *next;
}LNode, *LinkList;

LinkList creat(LinkList p)
{
    LinkList l, q;
    int ch;

       l = (LNode *) malloc( sizeof(LNode) );
    if ( l )
    {
        l->data = 0;
        l->next = NULL;
    }
    else
    {
        printf( "error\n" );
        return NULL;
    }                     

    q = l;   
    p = l;

    printf("Input the Incremental s:\n");
    scanf("%d",&ch);    //printf("%d\n",ch);

    while (ch != 0)                              
    {
        p = (LNode*)malloc(LEN);            
        p->data = ch;
        p->next = NULL;                    
        q->next = p;                    
        q = p;                       
        scanf("%d",&ch);
        //printf("%d\n",ch);
    
    }
/*    q = l;

    while (q->next != NULL)
    {
        printf(" %d",q->next->data);
        q = q->next;
    }*/

    return q;//It is OK!
}   

LinkList Merge_List(LinkList A, LinkList B, LinkList C)
{
    LinkList l;

/*    l = (LNode*)malloc(LEN);         
    l->data = '\0';                          
    l->next = NULL;  
*/

    l = (LNode *) malloc( sizeof(LNode) );
    if ( l )
    {
        l->data = 0;
        l->next = NULL;
    }
    else
    {
        printf( "error\n" );
        return NULL;
    }

//    A = l;
//    B = l;

    while (A->next != NULL)
    {
        printf(" %d",A->next->data);
        A = A->next;
    }

    while (B->next != NULL)
    {
        printf(" %d",B->next->data);
        B = B->next;
    }

/*    C = A;
    
    while (A->next != NULL && B->next != NULL)
    {
        if (A->data <= B->data)
        {
            C->next = A;
            C = A;
            A = A->next;
        }
        else
        {
            C->next = B;
            C = B;
            B = B->next;
        }
    }
    C->next = A ? A : B;

    C = l;
    while (C->next != NULL)
    {
        printf(" %d",C->next->data);
        C = C->next;
    }
*/

    free(A);
    free(B);

    return C;
}
/*
void Print(LinkList p)
{
    LinkList q;

    q = p;
    if (p != NULL)
        do {
            printf(" %d",p->data);
            p = p->next;
        }
        while (p != NULL);
        
    free(p);
}*/

int main()
{
    LinkList A, B, C;


    A = (LNode *) malloc( sizeof(LNode) );
    if ( A )
    {
        A->data = 0;
        A->next = NULL;
    }
    else
    {
        printf( "error\n" );
        return -1;
    }

    B = A;
    A = creat(A);
    B = creat(B);

/*    C = (LNode *) malloc( sizeof(LNode) );
    if ( C )
    {
        C->data = 0;
        C->next = NULL;
    }
    else
    {
        printf( "error\n" );
        return -1;
    }

*/

    C = A;
    C = Merge_List(A, B, C);

/*    while (C->next != NULL)
    {
        printf(" %d",C->next->data);
        C = C->next;
    }*/
    

//    Print(C);
    return 0;
}
此道是莱鸟我编得;但不能成功运行~我尝试许多方法,其中一种就是上面用的方法;发现程序好像总是不通过LinkList Merge_List函数~为什么??望各位高手指点~
搜索更多相关主题的帖子: 函数 
2008-09-30 19:39
很远的那颗星
Rank: 2
等 级:新手上路
威 望:4
帖 子:544
专家分:0
注 册:2008-6-30
得分:0 
你那什么LinkList Merge_List写得还真不好看,你写那么长做什么?

我看的痛苦..你要的话我重写一个给你看吧...反正还不到看恐怖片的时间...

Fighting~~~~~~~~
2008-09-30 19:43
hcanhong
Rank: 1
来 自:肇庆学院网络工程系
等 级:新手上路
帖 子:58
专家分:0
注 册:2008-9-6
得分:0 
回复 2# 很远的那颗星 的帖子
其实也不长~呵呵~谢咯~
2008-09-30 19:56



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




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

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