题目描述
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<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
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;
}