| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 602 人关注过本帖
标题:为什么链表不能输出????
取消只看楼主 加入收藏
hy247767221
Rank: 2
来 自:襄樊
等 级:论坛游民
帖 子:41
专家分:22
注 册:2011-7-27
结帖率:87.5%
收藏
已结贴  问题点数:5 回复次数:3 
为什么链表不能输出????
#include<stdio.h>
#include<stdlib.h>

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

LNode In_link(LNode head);
void Display_link(LNode head);
void Free_link(LNode head);

int main()
{
    LNode head = NULL, top = NULL;

    head = In_link(head);
    Display_link(head);
    putchar(10);

    top = In_link(top);
    Display_link(top);
    putchar(10);

    Free_link(head);
    Free_link(top);

    return 0;
}

LNode In_link(LNode head)
{
    int num;
    Node *link = NULL, *incept_link = NULL;

    printf("Please input the number:");
    scanf("%d", &num);
    while(num)
    {
        link = (Node *)malloc(sizeof(Node));
        link->data = num;
        if(head == NULL)
            head = link;
        else
            incept_link->next = link;
        incept_link = link;
        scanf("&d", &num);
    }
    if(incept_link != NULL)
        incept_link->next = NULL;
 
    return head;
}

void Display_link(LNode head)
{
    Node *incept_link = NULL;

    if(head == NULL)
    {
        printf("The link is empty!\n");
        return;
    }

    incept_link = head;
    while(incept_link)
    {
        printf("%3d", incept_link->data);
        incept_link = incept_link->next;
    }
}

void Free_link(LNode head)
{
    if(head == NULL)
    {
        printf("The link is empty!\n");
        return;
    }

    if(head->next)
        Free_link(head->next);
    Free_link(head);
}
搜索更多相关主题的帖子: include return 
2011-09-18 19:51
hy247767221
Rank: 2
来 自:襄樊
等 级:论坛游民
帖 子:41
专家分:22
注 册:2011-7-27
收藏
得分:0 
回复 3楼 nicum
不会啊,这不是无穷递归啊,以前有试过的··
2011-09-19 14:49
hy247767221
Rank: 2
来 自:襄樊
等 级:论坛游民
帖 子:41
专家分:22
注 册:2011-7-27
收藏
得分:0 
回复 5楼 hy247767221
楼上的哥们,表示抱歉,我犯了低级错误,格式控制符打错了
 scanf("&d", &num);
请原谅啦
其他的没有错误!!!
2011-09-19 15:53
hy247767221
Rank: 2
来 自:襄樊
等 级:论坛游民
帖 子:41
专家分:22
注 册:2011-7-27
收藏
得分:0 
回复 7楼 nicum
恩,对了,应该是这样的
void Free_link(LNode head)
{
    if(head == NULL)
    {
        printf("The link is empty!\n");
        return;
    }

    if(head->next)
        Free_link(head->next);
    free(head);
}
谢谢你啦,是我疏忽了,以后多交流!!!
2011-09-19 19:43
快速回复:为什么链表不能输出????
数据加载中...
 
   



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

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