有道难题,我的OO解法

简介:

本文背景是下面3篇文章:

"有道难题"之ealget的算法

看有道难题比赛有恶心感 ,付源码挑战,博客园目前纯速度最快。

有道难题之OO

 

正文:

第一个类是Cell类(萝卜坑):
Code

 

每一个萝卜坑维护有它和别的萝卜坑之间的关系。这样,每一个萝卜坑的Degree属性即是它的特殊程度,很容易算,不必知道萝卜坑在农田中的坐标。这样,萝卜坑就不必知道农田的存在了。为了避免边界条件,这里引入空对象,即EmptyCell。

然后是农田类Farmland:

Code

 

农田在初始化时就自动将萝卜坑之间的关系确定了。

哦,测试一下:

Code

 

结果:

1  land0:  0
2  land1:  3

 

这样写是不是更容易扩展,更容易维护?OO是朴素的,而不是教条的。

 --------------------------------------------------------------------------------------------------

似乎无法2小时内再发第二篇,那就接着这个向下写吧。

下面,使用泛型将这个问题再一般化。这里没有萝卜坑,没有农田,只有Cell和Cell容器MatrixCellContainer。

亮代码 :

Code

 

这样这代码的抽象度是不是更高些了?在上面泛型类基础上,用扩展方法也好,lambda表达式也好,要计算有道第一题是相当容易了。并且,这两个泛型类的用途远远不止有道第一题那种用途。讨论一下:

(1)想要在这个基础上计算新的测量,很容易;

(2)Cell<T>中的T不仅仅只限于int或double,也可以是任何其它类型,它维护的是一个抽象的类型实例之间的微观关系;

(3)MatrixCellContainer<T>维护的是类型实例之间的宏观关系;

(4)这两个类是不是也可以建模mud游戏的地图?是不是也可以用来建模俄罗斯方块之类的小游戏?。。。。

 

BTW. 我反对用OO来研究算法 写这篇文章的目的只是 ... 好玩 ...

本文转自xiaotie博客园博客,原文链接http://www.cnblogs.com/xiaotie/archive/2009/06/03/1495593.html如需转载请自行联系原作者


xiaotie 集异璧实验室(GEBLAB)

相关文章
|
1月前
|
算法
第四章 KMP算法理论基础
第四章 KMP算法理论基础
17 0
|
4月前
|
存储 算法 Python
震撼!Python算法设计与分析,分治法、贪心、动态规划...这些经典算法如何改变你的编程世界!
【7月更文挑战第9天】在Python的算法天地,分治、贪心、动态规划三巨头揭示了解题的智慧。分治如归并排序,将大问题拆解为小部分解决;贪心算法以局部最优求全局,如Prim的最小生成树;动态规划通过存储子问题解避免重复计算,如斐波那契数列。掌握这些,将重塑你的编程思维,点亮技术之路。
71 1
|
6月前
|
机器学习/深度学习 存储 算法
数据结构与算法①(第一章复杂度知识点)(大O渐进表示法)(下)
数据结构与算法①(第一章复杂度知识点)(大O渐进表示法)
34 0
|
6月前
|
存储 算法
数据结构与算法①(第一章复杂度知识点)(大O渐进表示法)(上)
数据结构与算法①(第一章复杂度知识点)(大O渐进表示法)
50 0
|
PHP
BugKu 矛盾 解题思路
BugKu 矛盾 解题思路
69 0
|
6月前
|
存储 缓存 算法
程序设计中的递归思想与实践
程序设计中的递归思想与实践
43 0
|
6月前
|
机器学习/深度学习 算法 Java
「程序员必须掌握的算法」动态规划「中篇」
「程序员必须掌握的算法」动态规划「中篇」
|
算法
贪心算法的思路和典型例题
贪心算法的思路和典型例题
|
存储 算法
递归算法设计技术
实验目的 实验内容 实验过程 程序清单 复杂度分析 运行结果
128 0
|
算法
分治法设计技术
设计一个程序,采用分治法求含n个实数序列中的最大元素和次大元素,并分析算法的时间复杂度 1.算法设计 2.程序清单 3.运行结果
156 0