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 overleaf中论文编辑,报错`pages' is a missing field, not a string, for entry 4
  • ¥15 vhdl+MODELSIM
  • ¥20 simulink中怎么使用solve函数?
  • ¥30 dspbuilder中使用signalcompiler时报错Error during compilation: Fitter failed,求解决办法
  • ¥15 gwas 分析-数据质控之过滤稀有突变中出现的问题
  • ¥15 没有注册类 (异常来自 HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG))
  • ¥15 知识蒸馏实战博客问题
  • ¥15 用PLC设计纸袋糊底机送料系统
  • ¥15 simulink仿真中dtc控制永磁同步电机如何控制开关频率
  • ¥15 用C语言输入方程怎么