二、数学模型的建立和比较
0 Y0 I6 s0 e8 c5 H! I2 s1 V由于考虑问题的角度不同,面对同一个实际问题,可能建立起各种各样的数学模型。在各种数学模型中,我们要寻找的是效率高的模型。模型的效率同模型的抽象化程度有关,下面从一个实例中来分析它们之间的具体关系。
\, y2 C4 X# q* K【多边形分割问题】将一个凸n边形用n-3条互不相交的对角线分割为n-2个三角形,求分割方案的总数. % F O3 E; b3 Q2 V0 J( b
f2 r$ _, \! `4 X0 B# K 这道题可用以下几种方法来求解:9 V* x' X7 h) D
<1>.搜索法: ' c1 v" P2 @$ _4 T
这种方法的思路是将各种分割方案全都列举出来。
# T) q- D Y3 P+ X6 V显然,一组n-3条互不相交的对角线对应于一种分割方案,因此可把问题看作是求不同的对角线组的数目。 & W+ m% _& p! w1 h: S& [
将n边形的n个顶点按顺时针方向编号为1、2、3……n,则一条对角线可表示为一个数对(a1,a2),a1、a2分别表示对角线两端顶点的序号,a1<a2,a1为对角线的始端,a2为末端。 m3 L- t, E h- G2 _, a1 M
对角线在对角线组中的顺序是无关紧要的,因此,一个对角线组是一个集合,它的元素是对角线。
. u7 L$ n4 g& L- H: h& D判断两条对角线是否相交是一个必须解决的问题。设两条对角线分别为(a1,a2)与(b1,b2),若把表示对角线的数对看作开区间,那么两条对角线不相交的充要条件是两个区间有包含关系或他们的交集为空集。
* {; ^& R2 O* R: V, z$ c* L: H+ l于是,我们建立起解决本问题的第一个数学模型:
! M' [- H2 y: [2 H2 t, a1 ?# d已知:n的值, ! b) g' Y) Y9 r4 c
一个集合由(n-3)个不同的开区间(i,j)组成, 1 S Y; d7 J3 z q, @
i∈{1..n-2}, j∈{i+2..n},(i≠1)或(j≠n)
/ v8 G: U, k$ p- n 同一个集合中任两个不同的开区间(i1,j1),(i2,j2)满足: 8 t. w# T- L* d' `' S
((i1,j1)∩(i2,j2)=空集)或((i1,j1)包含(i2,j2))或((i2,j2)包含(i1,j1))
2 N) w+ @) S4 Q5 H% S Y) L3 z求:不同的集合的个数 " S7 C; z$ e3 G D) ^
搜索时,先考虑以顶点1为始端的对角线,可以不连任何对角线(图一中A),也可以连(1,3)(图一中B),或连(1,4)(图一中C),或同时连(1,3)(1,4) (图一中D)。对于每一种情况,再考虑以顶点2为始端的对角线,依此类推。当得到n-3条互不相交的对角线时,便找到了一种方案
2 B s* y3 ?2 E- F" N2 _# l# ]$ t在考虑以顶点i为始端的对角线时,有以下几条规则必须遵循:
0 M/ X# b" x0 a- Y0 l& ?1.与原有对角线相交的对角线不得选取。
3 `7 Y+ b1 n4 g/ Q/ i- o2.当i>=3时,若顶点i-1为始端的对角线一条都未连,则对角线(i-2,i)必须是已经连的。 6 J+ x2 V: _. k6 h2 [+ j9 z) N
3.对角线的末端顶点序号必须大于i。否则,顶点i将成为对角线的末端,另一个顶点j(j<i)成为对角线的始端,这条对角线已在考虑以顶点j为始端的对角线时考虑过了,再考虑将引起重复。 2 g W: R. @8 `5 A4 a. n1 f5 u
按照以上三条规则,即可得到如图一的搜索树(图中打√的叶结点为不同的分割方案)。
8 ~5 t8 H; J" N' h搜索法的数学模型较为复杂,用它可以求出具体方案,但它的抽象化程度不高,导致了求解时的低效率。为了使用上面的规则2来提高效率,求解过程还是从多边形及其对角线本身来考虑的,数学模型的作用仅体现在判断对角线是否相交上。用该方法编制的程序在n稍大时速度就很慢。(n=12时已需运行时间16.2秒(486DX2/80),测试结果见附表一。)
2 U4 N/ ^' v0 F+ y |