WSS_ 2019-12-22 15:31 采纳率: 37.5%
浏览 366
已结题

求解,为什么没有输出???

/*Q4638.(10分)创建单向链表 要求:自定义函数create(),实现创建一个链表,
将此函数定义为指针类型,使其返回值为指针值,返回值指向一个struct LNode类型数据,实际上是返回链表的头指针。
在main()函数中调用自定义函数create(),实现创建一个链表,并将链表中的数据输出。
最后别忘了释放链表内存。这里使用malloc()函数实现动态开辟存储单元。
声明struct LNode类型,代码如下:
struct LNode
{
int data;
struct LNode next;
};
程序运行结果示例:
输入:
输入你想创建的结点个数:3
输入整数: 1 2 3
输出:
结果是: 1 2 3
输入提示:"输入你想创建的结点个数:"
输入格式:"%d"
输入提示:"输入整数:\n"
输入格式:"%d"
输出提示:"结果是:\n"
输出格式:"%d "
/

#include
#include
struct LNode
{

        int data;
        struct LNode *next;

}D;

struct LNode*create()
{
int n,i;

struct LNode*pHead=NULL,*pNew,*pTail;

printf("输入你想创建的结点个数:");

scanf("%d",&n);

printf("输入整数:\n");

for(i=0;i<n;i++)
{

            pNew=(struct LNode*)malloc(sizeof(struct LNode*));
            scanf("%d",&pNew->data);
            if(pHead==NULL) pHead=pNew=pTail;
    else
    {
        pTail->next=pNew;
        pTail=pNew;
    }       
}
    return pHead;

}

void List(LNode *pHead)
{
struct LNode *p=pHead;

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

}

int main()
{

LNode *p=NULL;
p=create();
printf("结果是:\n");
List(p);
void free(LNode *p);
return 0;

}

  • 写回答

1条回答

  • m0_46027060 2019-12-22 15:42
    关注

    你写成struct LNode next,next是什么?链表的话应该是struct LNode *next,用指针来遍历

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月7日
  • 已采纳回答 2月7日

悬赏问题

  • ¥15 自动转发微信群信息到另外一个微信群
  • ¥15 outlook无法配置成功
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换