| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 449 人关注过本帖
标题:求助!!!!链表,建立链表然后输出
只看楼主 加入收藏
Spygg
Rank: 5Rank: 5
等 级:职业侠客
帖 子:135
专家分:394
注 册:2007-5-20
结帖率:100%
收藏
已结贴  问题点数:5 回复次数:2 
求助!!!!链表,建立链表然后输出
#include<stdio.h>
#include<stdlib.h>
struct list
{
    int num;
    struct list *node;
};
main(void)
{
    struct list *head,*p,*tail;
    head=NULL;
    do
    {
        p=(struct list *)malloc(sizeof(struct list));
        if(p==NULL)
        {
            printf("Memonry alloc failed\n");
            exit(0);
        }
        printf("Input num\n");
        scanf("%d",&p->num);
        if(p->num==0)
        {
            free(p);
            break;
        }
        p->node=NULL;
        if(head==NULL)
        {
            head=p;
            tail=p;
        }
        else
        {
            tail->node=p;
            tail=p;
        }
    }while(p->num!=0);
        p=head;
        while(p!=NULL);
        {
            printf("%d",p->num);
            p=p->node;
        }
        printf("\n");
    }
   
搜索更多相关主题的帖子: 输出 链表 
2010-03-31 16:17
广陵绝唱
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:29
帖 子:3607
专家分:1709
注 册:2008-2-15
收藏
得分:5 
帮你简单改了下,你最马虎的地方是在输出时的 while 循环语句的后面加上了分号,导致死循环:

程序代码:
#include<stdio.h>
#include<stdlib.h>
struct list
{
    int num;
    struct list *node;
};
main()
{
    struct list *head,*p,*tail;
    head=NULL;
    do
    {
        p=(struct list *)malloc(sizeof(struct list));
        if(p==NULL)
        {
            printf("Memonry alloc failed\n");
            exit(0);
        }
        printf("Input num\n");
        scanf("%d",&p->num);
        //p->node=NULL;
        if(head==NULL)
        {
            head=p;
            tail=p;
        }
        else
        {
            tail->node=p;
            tail=p;
        }
     if(p->num==0)
        {
        p->node=NULL;
            //free(p);
            break;
        }
    }while(1);
   // tail->node=NULL;
        p=head;
        while(p->node!=NULL)
        {
            printf("%d ",p->num);
            p=p->node;
        }
        printf("\n");
    }

2010-03-31 17:27
Spygg
Rank: 5Rank: 5
等 级:职业侠客
帖 子:135
专家分:394
注 册:2007-5-20
收藏
得分:0 
回复 2楼 广陵绝唱
嗯,谢谢了,我当时是好不容易想 清楚了算法,不是很确定是否正确就写了程序,太慌张了
2010-04-03 08:20
快速回复:求助!!!!链表,建立链表然后输出
数据加载中...
 
   



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

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