| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 332 人关注过本帖
标题:为什么我输入 节点的个数 len = 0;怎不显示 分配失败 ??
取消只看楼主 加入收藏
X15810803158
Rank: 2
等 级:论坛游民
帖 子:49
专家分:36
注 册:2015-2-24
结帖率:91.67%
收藏
已结贴  问题点数:5 回复次数:0 
为什么我输入 节点的个数 len = 0;怎不显示 分配失败 ??

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

typedef struct node
{
    int date;//数据域
    struct node * pnext;//指针域

}NODE,*PNODE;//NODE等价于struct node,PNODE等价于struct node *;
//声明
PNODE creat_list(void);//创建一个链表,
void traverse_list(PNODE phead);

int main()
{
    PNODE phead = NULL;
    phead = creat_list();//创建一个链表,把头结点的地址赋给phead;
    traverse_list(phead);

    return 0;
}


PNODE creat_list(void)
{
    int len;//存放有效节点的个数
    int i;
    int val;//临时存放用户输入的节点的值

    //动态构造头结点
    PNODE phead = (PNODE)malloc(sizeof(NODE));
    if (NULL == phead)
    {
        printf("分配失败!");
        exit(-1);
    }
    PNODE ptail = phead;//构造尾节点
    ptail->pnext = NULL;

    printf("请输入节点的个数:len = ");
    scanf("%d",&len);

    for (i=0; i<len; i++)
    {
        printf("请输入第%d个节点的个数:",i+1);
        scanf("%d",&val);


        //动态构造一个新节点
        PNODE pnew = (PNODE)malloc(sizeof(NODE));
        if (NULL == pnew)
    {
        printf("分配失败!!\n");
        exit(-1);
    }

        pnew->date = val;
        ptail->pnext = pnew;//新节点挂在尾节点后
        pnew->pnext = NULL;
        ptail = pnew;

   
    }
   


  return phead;
}


 void traverse_list(PNODE phead)
{
    PNODE p = phead->pnext;
    while (NULL != p)
    {
        printf("%3d",p->date);
        p = p->pnext;
   
    }

printf("\n");

return ;

}
搜索更多相关主题的帖子: include return 
2015-11-12 22:31
快速回复:为什么我输入 节点的个数 len = 0;怎不显示 分配失败 ??
数据加载中...
 
   



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

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