现在的位置: 首页 > 综合 > 正文

符号三角形问题;回溯算法;子集树问题;时间复杂度O(2的n次方);

2013年02月27日 ⁄ 综合 ⁄ 共 1340字 ⁄ 字号 评论关闭

 

求+,-数量相等的三角形数量,整个三角形只与第一行的符号有关。

 

所以可以逐次安排第一行的每一个符号,由于每次安排好一个符号,那么就会在原确定的三角形最右侧加一条三角形边。 所以,利用回溯法,逐次对第一行每一个位置的符号做出选择,并且扩充新的三角形边。 为了实现回溯算法的优化,必须有剪枝函数,所以这里用+,-都小于总符号数的一半作为约束,只要能够递归到第n+1个字符,说明1到n个字符的安排都满足+<=half,-<=half,所以就是+与-数量相等,sum++。  为了在回溯过程中能够及时的计算出三角形的最新状况,所以设置了二维数组用于存储三角形,根据图形的关系可以求出三角形的右侧边加入到二维数组中。 

抱歉!评论已关闭.