Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1228912
  • 博文数量: 322
  • 博客积分: 10010
  • 博客等级: 上将
  • 技术积分: 3276
  • 用 户 组: 普通用户
  • 注册时间: 2009-12-17 09:21
文章分类

全部博文(322)

文章存档

2010年(155)

2009年(167)

我的朋友

分类: C/C++

2009-12-19 09:34:11

C程序员面试

(1)怎样才能检测到链表中存在循环


面试者可能如下作答

1.
  
对访问过的每个元素做个标记,继续遍历这个链表,如果遇到某个已经做过标记的元素,说明链表存在循环。
       
链表位于只读区域,无法在元素上做标记

2.
   
当访问每个元素时,把它存在一个数组里。检查每个后据元素,看看它是否已经存在 数组中。(哈哈,也许有些人继续想用散列表来优化数组的访问)
       
内存空间有限,无法创建一个足够长的数组。但是,可以假定如果链表中存在循环,那么它出现在前面的N个元素中

3.

设置一个指针,指向链表的头部。在接下去 对直到第N个元素的访问中,把N-1个元素依次同指向的元素进行比较。然后指针移向下一个元素,把同后面的N-2个元素进行比较。根据这个方法依次进行比较,如果出现比较相等的情况,就说明前N个元素中存在循环,否则如果所有N个元素两两之间进行比较都不相等,说明链表中不存在循环。

       
链表的长度是任意的,而且循环可能出现在任何位置。

4.
参考答案

 
首先,排除一种情况:3个元素的链表 ,第2个元素的后面是第一个元素。
         
设置两个指针P1P2,P1指向一个元素,P2指向第3个元素,看看它们是否相等。如果相等就属于上述这种特殊情况。

   
如果不等,把P1后移一个元素,P2后移两个元素。检查两个指针的值,如果相等,说明链表中存在循环。如果不相等,继续按照前述方法进行。如果出现两个指针都是NULL的情况,说明链表中不存在循环。

  
如果链表中存在循环,用这种方法一定能检查出来,因为其中一个指针肯定能追上另一个(两个指针具有相同的值),尽管可能要对这个链表经过几次遍历才能检测出来。


(2)不同的增值语句有什么区别

 

阅读(892) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~