百度面试题:一个单链表,长度未知,如何快速的找出位于中间的那个元素

问题:

一个单链表,长度未知,如何快速的找出位于中间的那个元素?

 

设置两个指针,p1,p2, 开始p1,p2均位于链接的头部。
p1 每次步进两步,
p2 每次步进一步
当p1到达链表的末尾时,p2所在的位置就是链表的中间元素

时间复杂度为O(n)

 

详细情况请见代码:

[cpp]  view plain copy
  1. #include <iostream>  
  2. using namespace std;  
  3. struct node{  
  4.   node *next;  
  5.   int data;   
  6. };  
  7. //用一个类封装链表的操作   
  8. class linknode{  
  9.     public:  
  10.     linknode(){  
  11.     head = new node;  
  12.     head->next = NULL;  
  13.     }  
  14.     ~linknode(){  
  15.       delete head;    
  16.     }  
  17.     //销毁所有资源   
  18.     void Clear(){  
  19.       node *p,*q;  
  20.       p = head;  
  21.       while(p){  
  22.         q = p->next;  
  23.       delete p;  
  24.       p = q;      
  25.       }  
  26.       //注意这里   
  27.       head->next = NULL;  
  28.       cout << "OK,destroyed all elements" << endl;  
  29.     }  
  30.     //尾插法   
  31.     void Create(int n){  
  32.         node *p,*q;  
  33.         int data;  
  34.         p = head;  
  35.        while(n--){  
  36.           q = new node;  
  37.           cout << "input data:";  
  38.           cin >> data;  
  39.           q->data = data;  
  40.           q->next = NULL;  
  41.           p->next = q;  
  42.           p = q;  
  43.        }  
  44.         
  45.     }  
  46.     void Output(){  
  47.        node *p;  
  48.        //注意,不要写成p = head;因为头结点没有保存数据   
  49.        p = head->next;  
  50.        while(p){  
  51.         cout << p->data << " ";  
  52.          p = p->next;  
  53.        }  
  54.        cout << endl;  
  55.     }  
  56.     //查找中间的元素   
  57.     node* findMid(){  
  58.         node *p1,*p2;  
  59.         p1 = head;  
  60.         p2 = head;  
  61.         while(p1 != NULL && p2 != NULL){  
  62.           p1 = p1->next->next;  
  63.           p2 = p2->next;   
  64.         }  
  65.         return p2;  
  66.     }  
  67.     private:  
  68.        node *head;  
  69. };  
  70. int main(){  
  71.   linknode lk;  
  72.   node *tmp;  
  73.   lk.Create(5);   
  74.   lk.Output();  
  75.   tmp = lk.findMid();  
  76.   cout << tmp->data << endl;  
  77.   lk.Clear();  
  78. }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值