网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
..net中判断该应用程序是否已经启.
.1998年4月全国计算机等级考试二级.
.C语言基础教程(一)基础篇.
.高质量C++/C编程指南 --&nb.
.在应用程序中使用热键的一段代码.
.数据结构学习(C++)之排序.
.C++中结构体的的慨念和使用方法.
.C++在网页设计中的应用.
.C++计算四则表达式的模板.
.用Delphi4的QReport部件生成报表.
.用纯粹的C++编写COM组件.
.原创:一个c++写的发牌程序.
.C++运算符重载转换运算符.
.C++入门解惑——浅析cout.
.获取操作系统的类型和版本.
.任意形状的窗体.
.C语言文件系统应用举例.
.C/C++语言void及void指针深层探索.
.新手入门:C++中布尔类型.
.使用foreach来读取记录.

链表的C语言实现之单链表的插入运算

发表日期:2008-3-8



  假设在一个单链表中存在2个连续结点p、q(其中p为q的直接前驱),若我们需要在p、q之间插入一个新结点s,那么我们必须先为s分配空间并赋值,然后使p的链域存储s的地址,s的链域存储q的地址即可。(p->link=s;s->link=q),这样就完成了插入操作。

  下例是应用插入算法的一个例子:

#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("没有查找到该数据!");
}

void insert(stud *p) /*插入函数,在指针p后插入*/
{
 char stuname[20];
 stud *s; /*指针s是保存新结点地址的*/
 if((s= (stud *) malloc(sizeof(stud)))==NULL)
 {
  printf("不能分配内存空间!");
  exit(0);
 }
 printf("请输入你要插入的人的姓名:");
 scanf("%s",stuname);
 strcpy(s->name,stuname); /*把指针stuname所指向的数组元素拷贝给新结点的数据域*/
 s->link=p->link; /*把新结点的链域指向原来p结点的后继结点*/
 p->link=s; /*p结点的链域指向新结点*/
}

main()
{
 int number;
 char fullname[20]; /*保存输入的要查找的人的姓名*/
 stud *head,*searchpoint;
 number=N;
 head=creat(number); /*建立新链表并返回表头指针*/
 printf("请输入你要查找的人的姓名:");
 scanf("%s",fullname);
 searchpoint=search(head,fullname); /*查找并返回查找到的结点指针*/
 insert(searchpoint); /*调用插入函数*/

} 更多文章 更多内容请看C/C++进阶技术文档专题,或
上一篇:编程者说之C语言 人气:515
下一篇:C++子对象和堆对象 人气:579
浏览全部C/C++的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐