m0_63508730 2021-11-24 22:06 采纳率: 100%
浏览 19
已结题

想用链表写,链表初始元素五个以上就老是输出不全,求解

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

typedef struct node
{
int data;
struct node* Pnext;
}NODE,*PNODE;

PNODE creat();
void sort_insert();
void traverse();

int main(int argc, char** argv)
{
PNODE p = NULL;
p = creat();
sort_insert(p);
traverse(p);
return 0;
}

PNODE creat(void)
{
int len;
int i;
int val;
PNODE Phead = (PNODE)malloc(sizeof(NODE));
if (Phead==NULL)
{
printf("头节点分配失败");
exit(-1);
}
PNODE Ptail = Phead;
Ptail->Pnext = NULL;
scanf("%d",&len);
for (i=0;i<len;++i)
{
PNODE Pnew = (PNODE)malloc(sizeof(NODE));
if (Pnew==NULL)
{
printf("新节点分配失败");
exit(-1);
}
scanf("%d",&val);
Pnew->data = val;
Ptail->Pnext = Pnew;
Ptail = Pnew;
Ptail->Pnext = NULL;
}
return Phead;
}

void traverse (PNODE p)
{
//PNODE pp = p->Pnext;
while(p->Pnext!=NULL)
{
p = p->Pnext;
printf("%d ",p->data);
}
return;
}

void sort_insert(PNODE p)
{
int val;
int i;
scanf("%d",&val);
while(p->Pnext->data < val)
{
p = p->Pnext;
}
PNODE Pnew = (PNODE)malloc(sizeof(NODE));
if (Pnew==NULL)
{
printf("新节点分配失败");
exit(-1);
}
Pnew->data = val;
PNODE tp;

  p->Pnext = tp;
  p->Pnext = Pnew;
  Pnew->Pnext = tp;
  return;

}

  • ```

![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/667717267736136.jpg "#left")
  • 写回答

2条回答 默认 最新

  • 关注

    sort_insert函数有问题,代码修改如下:

    #include <stdio.h>
    #include <malloc.h>
    #include <stdlib.h>
    
    typedef struct node
    {
        int data;
        struct node* Pnext;
    }NODE,*PNODE;
    
    PNODE creat();
    void sort_insert(PNODE p);
    void traverse(PNODE p);
    
    int main(int argc, char** argv)
    {
        PNODE p = NULL;
        p = creat();
        sort_insert(p);
        traverse(p);
        return 0;
    }
    
    PNODE creat(void)
    {
        int len;
        int i;
        int val;
        PNODE Phead = (PNODE)malloc(sizeof(NODE));
        if (Phead==NULL)
        {
            printf("头节点分配失败");
            exit(-1);
        }
        PNODE Ptail = Phead;
        Ptail->Pnext = NULL;
        scanf("%d",&len);
        for (i=0;i<len;++i)
        {
            PNODE Pnew = (PNODE)malloc(sizeof(NODE));
            if (Pnew==NULL)
            {
                printf("新节点分配失败");
                exit(-1);
            }
            scanf("%d",&val);
            Pnew->data = val;
            Ptail->Pnext = Pnew;
            Ptail = Pnew;
            Ptail->Pnext = NULL;
        }
        return Phead;
    }
    
    void traverse (PNODE p)
    {
        //PNODE pp = p->Pnext;
        while(p->Pnext!=NULL)
        {
            p = p->Pnext;
            printf("%d ",p->data);
        }
        return;
    }
    
    void sort_insert(PNODE p)
    {
        int val;
        int i;
        PNODE pre = p;
        PNODE q = pre->Pnext;
        scanf("%d",&val);
    
        while(q && q->data < val)
        {
            pre = q;
            q = q->Pnext;
        }
        PNODE Pnew = (PNODE)malloc(sizeof(NODE));
        if (Pnew==NULL)
        {
            printf("新节点分配失败");
            exit(-1);
        }
        Pnew->data = val;
        pre->Pnext = Pnew;
        Pnew->Pnext = q;
        /*PNODE tp;
    
        p->Pnext = tp;
        p->Pnext = Pnew;
        Pnew->Pnext = tp;*/
        return;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月3日
  • 已采纳回答 11月25日
  • 创建了问题 11月24日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵