NP完全问题 计蒜客2020蓝桥杯省赛A组模拟赛

思路:因为只是一道填空题,本题可以直接用暴力求解,也可以用dfs求解,这里只介绍dfs的思路。首先,30个元素,每个元素对应着选和不选两种情况。那么,在dfs一开始,我们先不选,一直递归到最后一个元素时再开始选。因为假如我们一开始便选了前面的元素,可能会导致我们还没看后面的元素,递归就结束了,显然这不是我们所期望的。同时应注意一点,因为这里我们定义的是全局变量,所以即使在选择的过程中,累加的和已经等于了我们所期望得到的值,此时最好也不要结束递归,而是等到我们递归到最后一个元素后,再结束递归。避免因为忘记回溯而出现问题。
代码如下

#include <stdio.h>
long long a[30]={70368744177669, 105553116266503, 123145302310920, 61572651155460, 30786325577730, 15393162788865, 78065325572101, 109401406963719, 125069447659528, 62534723829764, 31267361914882, 15633680957441, 78185584656389, 109461536505863, 125099512430600, 62549756215300, 31274878107650, 15637439053825, 78187463704581, 109462476029959, 125099982192648, 62549991096324, 31274995548162, 15637497774081, 78187493064709, 109462490710023, 125099989532680, 62549994766340, 31274997383170, 15637498691585},b[30],sum,f,ans=1019842928705602;
void dfs(int i,long long s)
{
	if(s==ans&&i==30)
	{
		f=1;
		for(int j=0;j<30;j++)
			printf("%lld",b[j]);
		return ;
	}
	if(s>ans||f||i>=30)	return ;
	b[i]=0;
	dfs(i+1,s);
	b[i]=1;
	dfs(i+1,s+a[i]);
}
int main()
{
	dfs(0,0);
	return 0;
}
posted @ 2020-03-06 20:16  键盘_书生  阅读(25)  评论(0编辑  收藏  举报