洛谷P2036-perket

题目描述

Perket 是一种流行的美食。为了做好 Perket,厨师们必须小心选择配料,以便达到更好的口感。你有N种可支配的配料。对于每一种配料,我们知道它们各自的酸度 S 和甜度 B。当我们添加配料时,总的酸度为每一种配料的酸度总乘积;总的甜度为每一种配料的甜度的总和。

众所周知,美食应该口感适中;所以我们希望选取配料,以使得酸度和甜度的绝对差最小。

另外,我们必须添加至少一种配料,因为没有美食是以白水为主要配料的。
输入格式

第一行包括整数 N,表示可支配的配料数。

接下来 N 行,每一行为用空格隔开的两个整数,表示每一种配料的酸度和甜度。

输入数据保证,如果我们添加所有配料,总的酸度和甜度都不会超过 10^9。
输出格式

输出酸度和甜度的最小的绝对差。
输入输出样例
输入 #1
1
3 10
输出 #1
7
输入 #2
4
1 7
2 6
3 8
4 9
输出 #2
1
说明/提示
1≤N≤10

蒟蒻第一次写博客,虽然之前也刷了一些题但是做完之后就放一边了,时间一久就忘记了,所以从今天开始我的博客生活了。
这是一道搜索题,刚开始会比较容易想到暴力法,简单的对每个组合进行判断然后记录最小值,因此就在暴力法上用深度搜索递归计算。看了代码应该问题不大。
#include
#include
#include
#include
using namespace std;
int flag[11]={0};//标记是否访问 
int a[11],b[11];//a表示酸度,b表示甜度 
int c=1,y=0;//酸度乘积,甜度累加 
int N;
int ans=0xfffffff;//初始为最大值 
void dfs(int x){//深度优先遍历 
	if(x>=N) return;
	else{
		for(int i=0;i<N;i++){
			if(flag[i]==0){
				c*=a[i];
				y+=b[i];
				flag[i]=1;
				ans=min(ans,abs(c-y));//更新答案 
				
				dfs(i+1);
				
				c/=a[i];//恢复现场 
				y-=b[i];
				flag[i]=0;
			}
		}
	}
}
int main(){
	cin>>N;
	for(int i=0;i<N;i++){
		cin>>a[i]>>b[i];
	}
	dfs(0);
	cout<<ans;
	return 0;
}

你可能感兴趣的:(洛谷入门题)