当前位置:  编程技术>c/c++/嵌入式

用C语言实现单链表的各种操作(二)

    来源: 互联网  发布时间:2014-10-15

    本文导语:  上一篇文章主要是单链表的一些最基本的操作,下面,主要是一些其他的典型的算法和测试程序。 代码如下:/* 对单链表进行排序处理*/struct LNode *sort(struct LNode *head){  LinkList *p;  int n,i,j;  int temp;  n = ListLength(head);  if(head == N...

上一篇文章主要是单链表的一些最基本的操作,下面,主要是一些其他的典型的算法和测试程序。
代码如下:

/* 对单链表进行排序处理*/
struct LNode *sort(struct LNode *head)
{
  LinkList *p;
  int n,i,j;
  int temp;
  n = ListLength(head);
  if(head == NULL || head->next == NULL)
    return head;
  p = head->next;
  for(j =1;jnext;
    for( i =0;idata > p->next->data)
      {
        temp = p->data;
        p->data = p->next->data;
        p->next->data = temp;
      }
      p = p->next;
    }
  }
  return head;
}
/*对单链表进行逆置*/
LinkList *reverse(LinkList *head)
{
  LinkList *p1,*p2 = NULL,*p3 = NULL;
  if(head == NULL || head->next == NULL)
    return head;
  p1 = head->next;
  while(p1!=NULL)
  {
    p3 = p1->next;
    p1->next = p2;
    p2 = p1;
    p1 = p3;
 }
 head->next = p2;
  // head = p2;
  return head;
}
Status equal(ElemType c1,ElemType c2)
{
  if(c1== c2)
    return TRUE;
  else
    return FALSE;
}
/*将所有在线性表Lb中但不在La中的数据元素插入到La 中*/
void Union(LinkList *La,LinkList *Lb)
{
  ElemType *e;
  int La_len,Lb_len;
  int i;
  La_len = ListLength(La);
  Lb_len = ListLength(Lb);
  for(i=1;inext;
    p = p->next->next;
  }
  return mid;
}

下面主要是单链表的一个测试的程序。
代码如下:

Status comp(ElemType c1,ElemType c2)
{
  if(c1==c2)
    return TRUE;
  else
    return FALSE;
}
void visit(ElemType c)
{
  printf("%4d",c);
}
void main()
{
  LinkList *L;
  LinkList *mid;
  mid = (struct LNode *)malloc(sizeof(struct LNode));

  ElemType *e,e0,*e1;
  Status i;
  int j,k;
  e = (ElemType *)malloc(sizeof(ElemType));
  e1 = (ElemType *)malloc(sizeof(ElemType));

  i = InitList(&L);
  for(j=1;jdata);

      printf("L逆置后的输出:L=");
      ListTraverse(reverse(L),visit);
    printf("L排序后依次为:L=");
    ListTraverse(sort(L),visit);

   
  i = ListEmpty(L);
  printf("L 是否为空:i=%d(1:是,0:否)n",i);
  i = ClearList(L);
  printf("清空L后:L=");
  ListTraverse(L,visit);
  i = ListEmpty(L);
  printf("L是否为空:i=%dn",i);
  for(j=1;j

    
 
 

您可能感兴趣的文章:

  • 可不可以这样认为!c语言是一道唯一指向操作系统的语言,精通了它,就了解了操作系统?
  • 操作系统一般是用什么语言编写的
  • 怎样用JAVA语言实现对串口的操作?
  • Linux 下的C语言实现数据库连接池操作。
  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • 求在linux下用c语言实现数据库连接池的操作。
  • C语言的JPEG操作库 OpenJPEG
  • 用C语言如何对img文件进行操作
  • 开发操作系统语言的选择?
  • 大家帮我推荐些在linux下用c语言对数据库操作编程的实例或资料吧!谢谢!
  • 请问LINUX下怎么用C语言对文件进行操作(包括新建、读取、删除、修改)
  • C语言编程——操作系统中的文件管理!
  • 请各位推荐几本UNIX下C语言编程学习的书!!(电子书籍也可)最好能详细介绍文件操作的!!!万分感谢!!!
  • c语言文件读写示例(c语言文件操作)
  • 用C语言在linux操作系统下编写MSN的客户端
  • 怎样在c语言的代码里内嵌的操作oracle数据库,各位大虾谢谢了
  • 我想写一个简单的操作系统,能不能推荐一下有关这方面的书?最好是C语言的
  • C语言操作数据库的一个小问题
  • C语言安全编码之数值中的sizeof操作符
  • 急!!在线等!! C语言程序操作mysql怎样在Linux上运行!!立刻揭贴!!
  • c语言判断某一年是否为闰年的各种实现程序代码
  • 如何在GTK2.0下实现国际化(语言选择根据自己设置的语言,不用系统的语言)
  • c语言实现MD5算法完整代码示例
  • 网站重定向用C语言实现iptables,ACL实现
  • Linux下C语言strstr()查找子字符串位置函数详细介绍(strstr原型、实现及用法)
  • C语言实现的mogstored守护进程 cmogstored
  • c语言基于libpcap实现一个抓包程序过程
  • 如何在linux下用c语言实现ftp编程
  • MD5算法的C语言实现
  • C语言的KD树实现 kdtree
  • 如何实现类似PHP.PB等语言中eval的函数功能?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 2013年7月和2013年8月编程语言排行榜
  • C语言中有指针,因此C语言可以创建链表,那么Java语言没有指针,那Java是否可以创建链表呢?
  • 2017 年热门编程语言排行榜出炉,你的语言上榜没?
  • 求助,在linux下,c语言和汇编语言的接口是什么?
  • 苹果OS X和IOS下最新编程语言swift介绍
  • C语言中间语言 CIL
  • PHP编程语言介绍及安装测试方法
  • 最近学JSP,苦于HTML语言和JAVA语言太差,请教推荐几本书,thanks.
  • 以NetBeans IDE为例介绍如何使用XML中Schema语言
  • 动态编程语言 LIME编程语言
  • 动态编程语言 LIME编程语言 iis7站长之家
  • C语言如何改变当前语言环境
  • HTML 脚本语言介绍及<script>标签用法
  • 如何在VIM中使汇编语言和C语言自动缩进?
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 我安装的linux时默认语言选择的是中文,又乱码,怎么可以解决?怎么更改默认语言成英文?
  • HTML 超文本标记语言简介
  • Redhat9安装时语言只选择了中文,现在还能再增加其它语言的支持吗?如英文
  • HTML语言特殊字符大全及其编码对照表(包括转义方式)
  • 请问哪里有ubuntu 9.0版本的中文语言包和KDE的中文语言包下载,我用Google搜索了很多地方都没有!
  • 据说这是史上最变态的6个C语言Hello, World程序
  • 请问如何在C语言中嵌入的shell脚本中获得C语言程序中定义的某个变量




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3