蓝桥杯2023年第十四届省赛真题-买瓜
该如何剪枝呢?⭐⭐
- 如果当前方案的切的刀数,已经大于等于了之前已知合法方案的最优解,那么就没必要
往后搜了。 - 如果后面的瓜的总和加起来,再加上当前已有的重量,都不到m,那么也没有必要搜索了。
- 如果你当前已有的重量超过了m,那么说明当前方案非法,直接return就好了。
- n个瓜遍历结束,你肯定要return。
- 我们将瓜从大到小排序,这是一个贪心。
这个代码有可能超时:
#include <iostream>
#include<bits/stdc++.h>
#define int long long
#define INF 0x3f3f3f3f
using namespace std;
const int N=100;
double a[N];
double s[N];
int n,m;
int ans