• 网络学院
  • IT资讯
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
链表的C语言实现之删除结点
  站点:
  • 首 页
  • 最新软件
  • 文章教程
  • 国内软件
  • 国外软件
  • 绿色软件
  • 源码下载
  • 字体下载
链表的C语言实现之删除结点
软件发布 链表的C语言实现之删除结点
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件 绿软下载
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回文章教程首页 >> 文章首页 >> 编程技术 >> C/C++教程 >> 链表的C语言实现之删除结点

链表的C语言实现之删除结点

添加时间: 2006-2-15 3:07:40  作者: C++教程  阅读次数:71   来源: http://d9soft.com

        假如我们已经知道了要删除的结点p的位置,那么要删除p结点时只要令p结点的前驱结点的链域由存储p结点的地址该为存储p的后继结点的地址,并回收p结点即可。

  以下便是应用删除算法的实例:

  

  #include <stdio.h>

  #include <malloc.h>

  #include <string.h>

  #define N 10

  typedef struct node

  {

   char name[20];

   struct node *link;

  }stud;

  

  stud * creat(int n) /*建立新的链表的函数*/

  {

   stud *p,*h,*s;

   int i;

   if((h=(stud *)malloc(sizeof(stud)))==NULL)

   {

    printf("不能分配内存空间!");

    exit(0);

   }

   h->name[0]='\0';

   h->link=NULL;

   p=h;

   for(i=0;i<n;i++)

   {

    if((s= (stud *) malloc(sizeof(stud)))==NULL)

    {

     printf("不能分配内存空间!");

     exit(0);

    }

    p->link=s;

    printf("请输入第%d个人的姓名",i+1);

    scanf("%s",s->name);

    s->link=NULL;

    p=s;

   }

   return(h);

  }

  

  stud * search(stud *h,char *x) /*查找函数*/

  {

   stud *p;

   char *y;

   p=h->link;

   while(p!=NULL)

   {

    y=p->name;

    if(strcmp(y,x)==0)

     return(p);

    else p=p->link;

   }

   if(p==NULL)

   printf("没有查找到该数据!");

  }   stud * search2(stud *h,char *x) /*另一个查找函数,返回的是上一个查找函数的直接前驱结点的指针,*/

  /*h为表头指针,x为指向要查找的姓名的指针*/

  /*其实此函数的算法与上面的查找算法是一样的,只是多了一个指针s,并且s总是指向指针p所指向的结点的直接前驱,*/

  /*结果返回s即是要查找的结点的前一个结点*/

  {

   stud *p,*s;

   char *y;

   p=h->link;

   s=h;

   while(p!=NULL)

   {

    y=p->name;

    if(strcmp(y,x)==0)

     return(s);

    else

    {

     p=p->link;

     s=s->link;

    }

   }

   if(p==NULL)

    printf("没有查找到该数据!");

  }

  

  void del(stud *x,stud *y) /*删除函数,其中y为要删除的结点的指针,x为要删除的结点的前一个结点的指针*/

  {

   stud *s;

   s=y;

   x->link=y->link;

   free(s);

  }

  

  main()

  {

   int number;

   char fullname[20];

   stud *head,*searchpoint,*forepoint;

   number=N;

   head=creat(number);

   printf("请输入你要删除的人的姓名:");

   scanf("%s",fullname);

   searchpoint=search(head,fullname);

   forepoint=search2(head,fullname);

   del(forepoint,searchpoint);

  }

 

上下文章:

 

上一篇文章: C#中实现DataGrid双向排序 下一篇文章: C++/CLI基本数据类型探索

相关文章:

  • 飞速在线看视频 傲盾加速帮你实现速度感受
  • 用端口碰撞技术实现服务器远程管理
  • servlet实现oracle中读出文件并显示
  • Oracle数据操作和控制语言详解
  • Oracle数据操作和控制语言详解

相关软件:

  • 顽固文件强行删除工具 V2.1
  • C语言资料大全 1.0
  • 易语言程序运行环境 4.11
  • C语言学习系统 V4.1
  • iTunes V7.6.2 多语言版
  • 易语言汉语编程环境 V4.10

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

编程技术分类导航

  • ASP & ASP.NET教程
  • PHP教程
  • JSP教程
  • C/C++教程
  • VB & VB.NET教程
  • VC教程
  • Delphi教程
  • BCB教程
  • VFP教程
  • PB教程
  • JAVA教程
  • XML教程
  • C#教程
  • CGI教程

本类经典文章推荐

  • C/C++作用域引申出的编码规范
  • 程序宝典:C++学习感想
  • C语言:黑客学员必修课(一)
  • C语言:黑客学员必修课(二)
  • 使用多线程实现数据实时采集
  • C++编程中的四个调试小技巧
  • C语言程序设计基础之联合
  • 学C++不得不看的一篇文章
  • C,曾经的程序员梦
  • 水滴石穿C语言之可变参数问题

C/C++教程阅读排行

  • 学C++不得不看的一篇文章
  • 水滴石穿C语言之可变参数问题
  • C语言:黑客学员必修课(一)
  • 程序宝典:C++学习感想
  • 我的Visual C++入门之路
  • 初学者学习C++的50条忠告
  • C++中的struct专题研究
  • C++箴言:只要可能就用const
  • 强大的语言——C入门
  • C++编程中的四个调试小技巧

编程技术阅读总排行

  • VB入门教程之一
  • Java连接数据库实例
  • 第二章 PowerBuilder 入门之创建新...
  • VC++之List Box/Check List Box控...
  • 第一章 什么是PowerBuilder
  • VC++ List Ctrl控件
  • VC++ Combo Box/Combo Box Ex控件
  • 学C++不得不看的一篇文章
  • VB入门教程之二
  • VC++之Button控件

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有