| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1322 人关注过本帖
标题:【求助】链表中节点的删除,有代码。
只看楼主 加入收藏
山丹老司机
Rank: 2
等 级:论坛游民
帖 子:20
专家分:12
注 册:2016-11-1
结帖率:80%
收藏
已结贴  问题点数:10 回复次数:4 
【求助】链表中节点的删除,有代码。
程序代码:
#include<stdio.h>
#include<stdlib.h>
#define LEN sizeof(NODE)


typedef struct node
{
    int a;
    struct node*next;
}NODE;

NODE* creat()
{
    int n=0;
    NODE*head=NULL;
    NODE*p1=NULL;
    NODE*p2=NULL;
    p1=p2=(NODE*)malloc(LEN);
    printf("enter\n");
    scanf("%d",&p1->a);
    while(p1->a != 0)
    {
        n++;
        if(n==1)head=p1;
        else
        {
            p2->next=p1;
            p2=p1;
            p1=(NODE*)malloc(LEN);
            scanf("%d",&p1->a);
        }
     } 
     p2->next=NULL;
     return head;     
}

NODE* del(int n,NODE*p)
{
    int k;
    NODE*q=NULL;
    NODE*head=NULL;
    head=p=q;
    for(k=0,head=p;k<n-1,p!=NULL;)//查找第n个节点 
    {
        p=p->next;
        k++;
    }
    q=p->next;                    //q成为要删除的节点 
    p->next=q->next;
    free(q);
    return head;
}


void print(NODE*p2)
{
    printf("%d",p2->a);
    p2=p2->next;
}
int main()
{
    NODE*p1=NULL;
    NODE*p2=NULL;
    p1=creat();
    int n;
    printf("enter\n");
    scanf("%d",&n);
    p2=del(n,p1);
    printf("print\n");
    print(p2);
}
2017-01-09 12:29
山丹老司机
Rank: 2
等 级:论坛游民
帖 子:20
专家分:12
注 册:2016-11-1
收藏
得分:0 
链表的创建是没有问题的,删除的那一部分有问题。
2017-01-09 12:30
bjut_Allen
Rank: 9Rank: 9Rank: 9
来 自:平乐园工业技术学校
等 级:蜘蛛侠
威 望:8
帖 子:323
专家分:1223
注 册:2016-10-16
收藏
得分:4 
#include<stdio.h>
#include<stdlib.h>
typedef struct node
{
    int a;
    struct node* next;
}NODE;

NODE* creat()
{
    int n=0,x;
    NODE* head=NULL;
    NODE* p1=NULL;
    NODE* p2=NULL;
   
    printf("建立链表\n");
    scanf("%d",&x);
    while(x!= 0)
    {
        p1=(NODE*)malloc(sizeof(NODE)*1);
        p1->a=x;
        n++;
        if(n==1){
            head=p1;
            p2=p1;
        }
        else
        {
            p2->next=p1;
            p2=p1;
        }
        scanf("%d",&x);
     }
     p2->next=NULL;
     return head;     
}

NODE* del(int n,NODE* p)
{
    int k;
    NODE* q=NULL;
    NODE* head=NULL;
    head=p;
    q=p;
    if(n==1){       //删除第一个节点
    p=p->next;
    head=p;
    return head;
    }
    for(k=0;k<n-2;k++)//查找第n个节点  
            p=p->next;
            
    if(p->next->next==NULL){          //如果想删最后一个节点
       q=p;
       q->next=NULL;
        p=p->next;
        free(p);
        return head;
    }
        
    q=p->next;                    //q成为要删除的节点
    p->next=q->next;
    free(q);
    return head;
}


void print(NODE* p2)
{
    do{
        printf("%d",p2->a);
    p2=p2->next;
    }while(p2!=NULL);
   
}
int main()
{
    NODE* p1=NULL;
    NODE* p2=NULL;
    p1=creat();
    int n;
    printf("输入删除节点位置\n");
    scanf("%d",&n);
    p2=del(n,p1);
    printf("print\n");
    print(p2);
    return 0;
}

Code is my life.
2017-01-09 15:52
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:2 
感觉删除节点用双向链表效率会更高,直接知道节点的ID就行了~单向的话直接知道ID还需要往前搜一遍,当然,看题目和具体环境以及个人兴趣咯~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-01-09 18:05
云团
Rank: 2
等 级:论坛游民
帖 子:36
专家分:41
注 册:2017-1-9
收藏
得分:4 
#include "stdio.h"
#include "stdlib.h"
#define LEN sizeof(NODE)
typedef struct node
 { int a;
     struct node *next;
 }NODE;
 NODE *creat()
  {
      NODE *p1,*p2,*head;
      head=(NODE *)malloc(LEN);
      p1=p2=(NODE *)malloc(LEN);
      head->next=p1;
      scanf("%d",&p1->a);
      while(p1->a!=0)
       {  p1=(NODE *)malloc(LEN);
           p2->next=p1;
           scanf("%d",&p1->a);
           p2=p1;
       }
       p2->next=NULL;
       return head;
  }
 int print(NODE *head)
  { NODE *p1,*p2;
      p1=head->next;
      printf("head->%d",p1->a);
    p1=p1->next;
      while(p1->next)
       { printf("->%d",p1->a);
            p1=p1->next;
       }
       printf("->end");
       return 0;
  }
  NODE *del(int n,NODE *head)
   { int k;
        NODE *p,*q;
        for(k=0,p=head;k!=n-1;k++) p=p->next;
        q=p->next;
        p->next=q->next;
        free(q);
        return head;
   }
  int main()
   { int n;
        NODE *head,*p1;
        head=creat();
        print(head);
        printf("\n\n input a number: ");
        scanf("%d",&n);
        head=del(n,head);
        print(head);
        printf("\n\n");
        return 0;
   }
收到的鲜花
  • bjut_Allen2017-01-10 09:18 送鲜花  10朵   附言:我很赞同
2017-01-09 20:18
快速回复:【求助】链表中节点的删除,有代码。
数据加载中...
 
   



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

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