标题:C语言双向链表插入不进去?是什么情况??
只看楼主
月樱极形
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2019-4-2
结帖率:100%
已结贴  问题点数:20 回复次数:7 
C语言双向链表插入不进去?是什么情况??
#include "stdio.h"
#include "malloc.h"
typedef struct DNode
{
  int data;
  struct DNode *prior,*next;
}DNode,*LinkList;
/*建立有n个结点的双链表*/
LinkList  create_link(LinkList head,int n)
{     
    LinkList  p, q;
    int i,x;
    head=(LinkList)malloc(sizeof(DNode));
    head->prior=NULL;
    head->next=NULL;
    p=head;
    for(i=1;i<=n;i++)
    {
        q=(LinkList)malloc(sizeof(DNode));
        printf("请输入结点值:");
        fflush(stdin);  /*清除键盘缓冲区*/
        scanf("%d",&x);
        q->data=x;
        p->next=q;
        q->prior=p;
        q->next=NULL;
        p=q;
    }
        return(head);
}
/*双链表各个结点值的输出:*/
void ListPint_L(LinkList head)
{
 LinkList p;
 
 p=head->next;
 while(p!=NULL)
 {
 
  printf("%3d\n",p->data);
  p=p->next;
  }
}

/*在双链表中插入一个数据*/
int insert_link(LinkList head,int e,int i)
{
    LinkList p,s;
    int j;
    head=(LinkList)malloc(sizeof(DNode));
    head->prior=NULL;
    head->next=NULL;
    p=head->next;
    while(j<i&&p->next!=NULL)
    {
        j++;
        p=p->next;
    }
    if(j>i)
        return 0;
    s=(LinkList)malloc(sizeof(DNode));
    s->data=e;
    s->next=p;
    s->prior=p->prior;
    p->prior->next=s;
    p->prior=s;
    return 1;
}
void main( )
{
 int i,e;
 LinkList head;
 head=(LinkList)malloc(sizeof(DNode));
 head->prior=NULL;
 head->next=NULL;
 head=create_link(head,5);
 printf("输出结果是:\n");
 ListPint_L(head);
 printf("请输入你要插入的数据:");
 fflush(stdin);
 scanf("%d",&e);
 printf("请输入你要插入的位置:");
 scanf("%d",&i);
 insert_link(head,e,i);
 ListPint_L(head);
}

(运行结果)
搜索更多相关主题的帖子: malloc int next head NULL 
2019-04-02 10:52
ZJYTY
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:92
专家分:700
注 册:2018-12-20
得分:10 
程序代码:
#include "stdio.h"
#include "malloc.h"
typedef struct DNode
{
    int data;
    struct DNode *prior, *next;
}DNode, *LinkList;
/*建立有n个结点的双链表*/
LinkList  create_link(LinkList head, int n)
{
    LinkList  p, q;
    int i, x;
    head = (LinkList)malloc(sizeof(DNode));
    head->prior = NULL;
    head->next = NULL;
    p = head;
    for (i = 1; i <= n; i++)
    {
        q = (LinkList)malloc(sizeof(DNode));
        printf("请输入结点值:");
        fflush(stdin);  /*清除键盘缓冲区*/
        scanf("%d", &x);
        q->data = x;
        p->next = q;
        q->prior = p;
        q->next = NULL;
        p = q;
    }
    return(head);
}
/*双链表各个结点值的输出:*/
void ListPint_L(LinkList head)
{
    LinkList p;

    p = head->next;
    while (p != NULL)
    {

        printf("%3d\n", p->data);
        p = p->next;
    }
}

/*在双链表中插入一个数据*/
int insert_link(LinkList head, int e, int i)
{
    LinkList p, s;
    int j = 0;                                   //给定J初值
    p = (LinkList)malloc(sizeof(DNode));         //不要改变head
    p->prior = NULL;
    p = head;
    p->next = head->next;
    while (j < i&&p->next != NULL)
    {
        j++;
        p = p->next;
    }
    if (j > i)
        return 0;
    s = (LinkList)malloc(sizeof(DNode));
    s->data = e;
    s->next = p;
    s->prior = p->prior;
    p->prior->next = s;
    p->prior = s;
    return 1;
}
void main()
{
    int i, e;
    LinkList head;
    head = (LinkList)malloc(sizeof(DNode));
    head->prior = NULL;
    head->next = NULL;
    head = create_link(head, 5);
    printf("输出结果是:\n");
    ListPint_L(head);
    printf("请输入你要插入的数据:");
    fflush(stdin);
    scanf("%d", &e);
    printf("请输入你要插入的位置:");
    scanf("%d", &i);
    insert_link(head, e, i);
    ListPint_L(head);
    getchar();
    getchar();
}

-------------------------------若有不当之处,敬请谅解-------------------------------
2019-04-02 14:38
yuyundong
Rank: 2
等 级:论坛游民
威 望:2
帖 子:19
专家分:45
注 册:2019-2-18
得分:6 
大量的内存泄漏
head不要随意赋值,也不能随意移动
上一位解决了插入问题,但内存泄漏没有注意

    LinkList p, s;
    int j = 0;                                   //给定J初值
    p = (LinkList)malloc(sizeof(DNode));         //不要改变head
    p->prior = NULL;
    p = head;
    p->next = head->next;
这里 p 最初指向的空间没有delete就被head指向的空间覆盖了,就是说这里malloc的空间泄漏
2019-04-02 18:06
yuyundong
Rank: 2
等 级:论坛游民
威 望:2
帖 子:19
专家分:45
注 册:2019-2-18
得分:0 
大量的内存泄漏
head不要随意赋值,也不能随意移动
上一位解决了插入问题,但内存泄漏没有注意

    LinkList p, s;
    int j = 0;                                   //给定J初值
    p = (LinkList)malloc(sizeof(DNode));         //不要改变head
    p->prior = NULL;
    p = head;
    p->next = head->next;
这里 p 最初指向的空间没有delete就被head指向的空间覆盖了,就是说这里malloc的空间泄漏
2019-04-02 18:07
月樱极形
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2019-4-2
得分:0 
回复 2楼 ZJYTY
谢谢解惑!!!!
2019-04-02 23:45
月樱极形
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2019-4-2
得分:0 
回复 3楼 yuyundong
能不能详细解释一下,有点不明白。
2019-04-02 23:47
ZJYTY
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:92
专家分:700
注 册:2018-12-20
得分:0 
回复 4楼 yuyundong
多谢提醒

-------------------------------若有不当之处,敬请谅解-------------------------------
2019-04-03 08:55
ZJYTY
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:92
专家分:700
注 册:2018-12-20
得分:4 
回复 6楼 月樱极形
那段代码指针p在指向一片新的空间后,又重新指向了head所指的空间

-------------------------------若有不当之处,敬请谅解-------------------------------
2019-04-03 08:57



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-493916-1-1.html




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

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