zoukankan      html  css  js  c++  java
  • 链表-单链表的各种操作

    单链表的结构体的定义

    typedef struct LNode
    {
     ElemType data;
     struct LNode *next;
    }LinkList;

    基本的单链表的操作

    /* 功能:构建一个空的带头节点的单链表*/
    Status InitList (struct LNode **L)
    {
      (*L) = (struct LNode *)malloc(sizeof(struct LNode)); //产生头节点
    
      if(!*L)
       exit(OVERFLOW);
      (*L)->next = NULL;
      return OK;
    }
    /*销毁线性表*/
    Status DestroyList(struct LNode *L)
    {
      struct LNode *q;
      while(L)
      {
        q = L->next;
        free(L);
        L = q;
      }
      return OK;
    }
    /*将L重置为空表*/
    Status ClearList(struct LNode *L)
    {
      LinkList *p,*q;
      p = L->next;
      while(p)
      {
        q = p->next;
        free(p);
        p = q;
      }
      L->next = NULL;
      return OK;
    }
    /*判断链表是否为空表*/
    Status ListEmpty(LinkList *L)
    {
      if(L->next)
      {
        return FALSE;
      }
      else
      {
        return TRUE;
        
      }
    }
    /*返回单链表中元素的个数*/
    int ListLength(struct LNode *L)
    {
      int i=0;
      LinkList *p = L->next;
      while(p)
      {
        i++;
        p = p->next;
      }
      return i;
    }
    /* L为带头节点的单链表的头指针,当第i个元素存在时,其值赋给e,并返回OK */
    Status GetElem(struct LNode *L,int i,ElemType *e)
    {
      int j=1;
      LinkList *p = L->next;
      while(p && j<i)
      {
        p = p->next;
        j++;
      }
      if(!p || j>i)
        return ERROR;
      *e = p->data;
      return OK;
    }
    /*返回L中第一个与e满足关系compare()的数据元素的位序,
     若给存在返回值为0,compare()是数据元素的判定函数*/
    int LocateElem(struct LNode *L,ElemType e,Status(*compare) (ElemType,ElemType))
    {
      int i =0;
      LinkList *p = L->next;
      while(p)
      {
        i++;
        if(compare(p->data,e))
          return i;
        p=p->next;
      }
      return 0;
    }
    /*所cur_e是L中的数据元素,且给就第一个,则用pre_e返回它的前驱*/
    Status PriorElem(struct LNode *L,ElemType cur_e,ElemType *pre_e)
    {
      LinkList *q,*p=L->next;
      while(p->next)
      {
        q = p->next;//q指向p的后继
    
        if(q->data == cur_e)
        {
          *pre_e = p->data;
          return OK;
        }
        p = q;
      }
      return INFEASIBLE;
      
    }
    /* 若cur_e是L中的数据元素,且不是最后一个,则用next_e返回它的后继*/
    Status NextElem(struct LNode *L,ElemType cur_e,ElemType *next_e)
    {
      LinkList *p;
      p = L->next;
      while(p->next)
      {
        if(p->data == cur_e)
        {
         * next_e = p->next->data;
          return OK;
        }
        p = p->next;
      }
      return INFEASIBLE;
    }
    /* 在带头节点的单链表L中的第i个位置之前插入元素e*/
    Status ListInsert(struct LNode *L,int i,ElemType e)
    {
      int j =0;
      struct LNode *p=L,*s=NULL;
      while(p && j<i-1)
      {
        p=p->next;
        j++;
      }
      if(!p || j>i-1)
        return ERROR;
      s = (struct LNode *)malloc(sizeof(struct LNode));
      if(!s)
        printf("malloc error~
    ");
      // p->next = s;
    
      s->data = e;
      // p->next = s;
    
       s->next = p->next;
       p->next = s;
       //s->next = NULL;
    
      // p = s;
    
      return OK;
    }
    /*在带头节点的单链表中删除第i个元素,并有e返回其值*/
    Status ListDelete(LinkList *L,int i,ElemType *e)
    {
     
      LinkList *p=L,*q;
      
       int j=0;
      while(p->next && j< i-1)
      {
        p = p->next;
        j++;
      }
    
      if(!p->next || j>i-1)
        return ERROR;
      q = p->next;
      p->next = q->next;
      *e = q->data;
      free(q);
      return OK;
      }
    /* 依次对L的每个元素调用vi(),打印输出语句*/
    Status ListTraverse(struct LNode *L,void (*vi)(ElemType))
    {
      LinkList *p = L->next;
      while(p)
      {
        vi(p->data);
        p = p->next;
      }
      printf("
    ");
      return OK;
    }
  • 相关阅读:
    京东Java面试题(二)
    京东Java面试题(一)
    阿里java面试题
    Java垃圾回收机制
    MyBatis面试题
    Java IO流总结
    Spring中文文档
    Vue.js实战之组件之间的数据传递
    Vue.js实战之Vuex的入门教程
    Vue系列——在vue项目中使用jQuery及其第三方插件
  • 原文地址:https://www.cnblogs.com/ye1031/p/4806047.html
Copyright © 2011-2022 走看看