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 qt+ffmpeg报错non-existing PPS 0 referenced
  • ¥15 FOC simulink
  • ¥15 咨询一下有关于王者荣耀赢藏战绩
  • ¥50 MacOS 使用虚拟机安装k8s
  • ¥500 亚马逊 COOKIE我如何才能实现 登录一个亚马逊账户 下发新 COOKIE ..我使用下发新COOKIE 导入ADS 指纹浏览器登录,我把账户密码 修改过后,原来下发新COOKIE 不会失效的方式
  • ¥20 玩游戏gpu和cpu利用率特别低,玩游戏卡顿
  • ¥25 oracle中的正则匹配
  • ¥15 关于#vscode#的问题:把软件卸载不会再出现蓝屏
  • ¥15 vimplus出现的错误
  • ¥30 怎么使用AVL fire ESE软件自带的优化模式来优化设计Soot和NOx?