这道题一看数据规模就知道是爆搜

是一道还不错的DFS练习题

只要每一次尝试顺时针或逆时针转,转完之后计算是否转回0°就好了

注意如果逆时针转,不能直接减去度数,会变成负数。

代码:

#include<iostream>
using namespace std;
bool flag=true;//有没有得到解
int a[20];//转动度数
void dfs(int nd,int n){
	if(n==-1){
		if(nd%360==0)
			flag=false;
		return;
	}//判断是否转回0°
	if(flag)
		dfs(nd+a[n],n-1);//向下搜
	if(flag)
		dfs(nd+360-a[n],n-1);//向下搜
}
int main()
{
	int n;
	cin>>n;
	for(int i=0;i<n;i++)
		cin>>a[i];//输入
	dfs(0,n-1);//递归
	if(flag)
		cout<<"NO\n";
	else
		cout<<"YES\n";//输出
	return 0;
}
//个人认为代码可读性还是可以的吧