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

来源:互联网 发布:php商城开源 编辑:程序博客网 时间:2024/05/16 05:53

 

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

 

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

原创粉丝点击