课程表

CoffeeScript 语法

CoffeeScript 类和对象

CoffeeScript 字符串

CoffeeScript 数组

CoffeeScript 日期和时间

CoffeeScript 数学

CoffeeScript 方法

CoffeeScript 元编程

CoffeeScript jQuery

CoffeeScript 正则表达式

CoffeeScript 网络

CoffeeScript 设计模式

CoffeeScript 数据库

CoffeeScript 测试

工具箱
速查手册

CoffeeScript 策略模式

当前位置:免费教程 » JS/JS库/框架 » CoffeeScript

问题

解决问题的方式有多种,但是你需要在程序运行时选择(或是转换)这些方法。

解决方案

在策略对象(Strategy objects)中封装你的算法。

例如,给定一个未排序的列表,我们可以在不同情况下改变排序算法。

基类

  1. StringSorter = (algorithm) ->
  2. sort: (list) -> algorithm list

策略

  1. bubbleSort = (list) ->
  2. anySwaps = false
  3. swapPass = ->
  4. for r in [0..list.length-2]
  5. if list[r] > list[r+1]
  6. anySwaps = true
  7. [list[r], list[r+1]] = [list[r+1], list[r]]
  8. swapPass()
  9. while anySwaps
  10. anySwaps = false
  11. swapPass()
  12. list
  13. reverseBubbleSort = (list) ->
  14. anySwaps = false
  15. swapPass = ->
  16. for r in [list.length-1..1]
  17. if list[r] < list[r-1]
  18. anySwaps = true
  19. [list[r], list[r-1]] = [list[r-1], list[r]]
  20. swapPass()
  21. while anySwaps
  22. anySwaps = false
  23. swapPass()
  24. list

使用策略

  1. sorter = new StringSorter bubbleSort
  2. unsortedList = ['e', 'b', 'd', 'c', 'x', 'a']
  3. sorter.sort unsortedList
  4. # => ['a', 'b', 'c', 'd', 'e', 'x']
  5. unsortedList.push 'w'
  6. # => ['a', 'b', 'c', 'd', 'e', 'x', 'w']
  7. sorter.algorithm = reverseBubbleSort
  8. sorter.sort unsortedList
  9. # => ['a', 'b', 'c', 'd', 'e', 'w', 'x']

讨论

“没有作战计划在第一次接触敌人时便能存活下来。” 用户如是,但是我们可以运用从变化的情况中获得的知识来做出适应改变。在示例末尾,例如,数组中的最新项是乱序排列的,知道了这个细节,我们便可以通过切换算法来加速排序,只要简单地重赋值就可以了。

练习

  • 将 StringSorter 扩展为 AlwaysSortedArray 类来实现规则序列的所有功能,但是要基于插入方法自动分类新的项(例如 push 对比 shift)。
转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号