法中引进的附加记录R[0]称监视哨或哨兵(Sentinel)。
哨兵有两个作用:
① 进人查找(插入位置)循环之前,它保存了R[i]的副本,使不致于因记录后移而丢失R[i]的内容;
② 它的主要作用是:在查找循环中监视下标变量j是否越界。一旦越界(即j=0),因为R[0].可以和自己比较,循环判定条件不成立使得查找循环结束,从而避免了在该循环内的每一次均要检测j是否越界(即省略了循环判定条件j>=1)。
注意:
① 实际上,一切为简化边界条件而引入的附加结点(元素)均可称为哨兵。
【例】单链表中的头结点实际上是一个哨兵
② 引入哨兵后使得测试查找循环条件的时间大约减少了一半,所以对于记录数较大的文件节约的时间就相当可观。对于类似于排序这样使用频率非常高的算法,要尽可能地减少其运行时间。所以不能把上述算法中的哨兵视为雕虫小技,而应该深刻理解并掌握这种技巧。
相关文章
- 【面试题】三道面试题让你掌握JavaScript中的执行上下文与作用域以及闭包
- 想不想修真清灵草的作用与功效是什么 清灵草怎么获得
- 我的侠客天气有什么用 天气的作用详解
- 和平精英里的金币作用 和平精英里的金币能干什么
- 我的起源生命石的作用是什么 生命石的获取位置一览
- Vue框架:9,Vue3的用法,setup函数,ref和reactive,计算属性和监听属性,生命周期,toRefs,script setup的作用和lang,Vue后台管理模板
- 你不知道的JavaScript(作用域和闭包)
- 《你不知道的JavaScript》读书笔记(一)作用域
- 《你不知道的JavaScript》读书笔记(二)词法作用域
- JavaScript词法作用域—你不知道的JavaScript上卷读书笔记(一)