单链表的常见题型汇总

本文汇总了常见的单链表面试题,包括单链表反转、求倒数第N个数、找到中间结点、判断是否有环、建立环、计算环长度、找出环的连接点以及删除重复元素等。并提供了简洁的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:http://leihuang.org/2014/05/19/List-Interviews/

单链表的一些常见面试题汇总

  1. 单链表反转/逆序
  2. 求单链表倒数第N个数
  3. 找到单链表的中间结点
  4. 如何判断链表是否有环的存在
  5. 单链表建环,无环链表变有环
  6. 如何知道环的长度?
  7. 如何找出环的连接点在哪里?
  8. 删除单链表中的重复元素

下面我先简单叙述一下每道题的思路,然后把实现的程序一起贴出来,不会讲得太细,我觉得只要有了思路之后,接下来的难点就是语言上的一些细节问题了,这个不自己去实现,听别人讲是体会不到的。 要实现下面的代码你首先要会实现单链表, see:线性表

1.单链表反转

我是利用三个指针来实现的,三个连续指针依次向前移动,每次反转前两个指针指向数之间的指针。

代码如下:

/* 链表反转  */
void ReverseList(List *L)
{
    if(!L->Next->Next)
        ;
    else{
        List *pTemp = L->Next->Next->Next ;
        List *pMid = L->Next->Next ;
        List *pCurrent = L->Next ;
        L->Next->Next = NULL ;
        while(pTemp){
            pMid->Next = pCurrent ;
            pCurrent = pMid ;
            pMid = pTemp ;
            pTemp = pTemp->Next ;
        }
        pMid->Next = pCurrent ;
        L->Next = pMid ;
    }
}


2.求单链表倒数第N个数

利用两指针遍历表,保持他们的距离为n,当后面的指针为NULL时,输出前面指针所指向的数,即倒数第N个数。

函数代码:

/* 求单链表倒数第N个数 */
int NIndex(List L,int n)
{
    List *fir,*sec ;
    fir = L.Next ;
    sec = L.Next ;
    int i ;
    for(i=0;sec;++i){
        if(i>=n){
            fir = fir->Next ;
            sec = sec->Next ;
        }else
            sec = sec->Next ;
    }
    return fir->elem ;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值