Chinaunix首页 | 论坛 | 博客
  • 博客访问: 245314
  • 博文数量: 35
  • 博客积分: 198
  • 博客等级: 入伍新兵
  • 技术积分: 443
  • 用 户 组: 普通用户
  • 注册时间: 2010-11-28 10:30
文章分类

全部博文(35)

文章存档

2015年(5)

2014年(14)

2013年(8)

2012年(7)

2011年(1)

我的朋友

分类: C/C++

2013-04-09 23:21:01

今天面试出来一道题,要求对双链表进行插入与删除操作,好久都没写过链表的操作了,觉得有意思,晚上将内容贴出来。
双链表结构如下,它不是一般的双链表,有前驱和后继,这个链表有个指向下一个节点的指针和指向下一个节点的下个节点指针。

  1. typedef struct tagNode{
  2.     struct tagNode* pnext ;//指向下一个节点
  3.     struct tagNode* ppnext ;//指向下一个节点的下一个节点
  4. }Node;

  5. typedef Node* LList ;

下面提供如何创建链表,毁灭链表等函数。

  1. /************************************************************************/
  2. /* 创建链表 */
  3. /************************************************************************/
  4. LList create_list()
  5. {
  6.     Node* p = new Node ;
  7.     p->pnext = NULL;
  8.     p->ppnext = NULL;
  9.     return p ;
  10. }
  11. /************************************************************************/
  12. /* 创建新节点 */
  13. /************************************************************************/
  14. Node* create_new_node()
  15. {
  16.     Node* p = new Node ;
  17.     p->pnext = NULL;
  18.     p->ppnext = NULL;
  19.     return p ;
  20. }
  1. /************************************************************************/
  2. /* 在链表尾端插入新节点 */
  3. /************************************************************************/
  4. void insert_node(LList head,Node* pNode)
  5. {
  6.     Node* pb=head->pnext;
  7.     Node* pbb=head;
  8.     Node* ps= head->ppnext;
  9.     while(ps)
  10.     {
  11.         pbb = pb ;
  12.         pb = ps;
  13.         ps = ps->pnext;
  14.     }
  15.     if(pb) //如果父节点不为NULL
  16.     {
  17.         pbb->ppnext = pNode;
  18.         pb->pnext = pNode;
  19.         pb->ppnext = NULL;
  20.     }else//父节点为NULL
  21.     {
  22.         pbb->pnext = pNode;
  23.         pbb->ppnext =NULL;
  24.     }
  25.     
  26. }
  1. /************************************************************************/
  2. /* 毁灭(删除)链表 */
  3. /************************************************************************/
  4. void destroy_list(LList head)
  5. {
  6.     Node* p = head ;
  7.     Node* q;
  8.     while(p)
  9.     {
  10.         q=p ;
  11.         p=p->pnext;
  12.         delete q ;
  13.     }
  14. }
  15. /************************************************************************/
  16. /* 遍历链表 */
  17. /************************************************************************/
  18. void visit_list(LList list)
  19. {
  20.     Node* p = list ;
  21.     while(p)
  22.     {
  23.         printf("current_addr=[%p] son_addr=[%p] son_son_addr=[%p] \n",p,p->pnext,p->ppnext);
  24.         p=p->pnext;
  25.     }
  26. }

  1. /************************************************************************/
  2. /* 删除链表的指定节点,但是不能删除头节点,删除头节点有问题 */
  3. /************************************************************************/
  4. void delete_node(LList list,Node* pNode)
  5. {
  6.     if(list == pNode || pNode == NULL)
  7.     {
  8.         return ;
  9.     }

  10.     Node* pb=list;//指向当前节点的父节点
  11.     Node* pbb=list;//指向当前节点爷爷节点
  12.     Node* pc= list;//指向当前节点
  13.     while(pc && pc != pNode)
  14.     {
  15.         pbb = pb ;
  16.         pb = pc;
  17.         pc = pc->pnext;
  18.     }
  19.     if(pc)//说明找到了pc==pNode的节点,否则pc==NULL
  20.     {
  21.         pb->pnext = pc->pnext;
  22.         pb->ppnext = pc->ppnext;
  23.         pbb->ppnext = pc->ppnext;
  24.     }
  25. }







  1. /************************************************************************/
  2. /* 创建新节点 */
  3. /************************************************************************/
  4. Node* create_new_node()
  5. {
  6.     Node* p = new Node ;
  7.     p->pnext = NULL;
  8.     p->ppnext = NULL;
  9.     return p ;
  10. }
阅读(4803) | 评论(0) | 转发(5) |
给主人留下些什么吧!~~