当前位置: 首页 > article >正文

[蓝桥杯 2023 省 A] 买瓜 --暴力DFS+剪枝优化

题目来自洛谷:

暴力思路:

①根据题目,可以知道有三种操作,第一种操作选择这个瓜,第二种操作不选择这个瓜,第三种操作选择这个瓜的一半。我们可以用一个res来记录这三种操作返回的结果,最后在返回这三种操作的最小值。

②从数据样例中知道,对于第三种操作,在进行切一半操作的时候,数据类型会发生改变,int只能存整数,这样会导致答案错误。因此我们存数据前对数据进行*2操作,同时我们的总重量也要 m*2。

③由于本题数据过大,会爆int,我们要用long long 来存。

#include<bits/stdc++.h>
//long long 来存数据
#define int long long
using namespace std;
const int N = 40;

int n, m;
int arr[N];//存数据
int w[N]; //后缀和

//x表示枚举瓜 sum 表示当前重量
int dfs(int x, int sum){
    if(sum == 2*m){
        return 0;
    }
    //遍历完了所有瓜
    if(x > n){
        return N;
    }
    //当前重量超过总重量 不合法
    if(sum > 2*m){
        return N;
    }
    //当前重量+加上当前点后缀和小于总重量 不合法
    if(sum + w[x] < 2*m){
        return N;
    }
    //直接选
    int res1 = dfs(x+1, sum + arr[x]);
    //选一半
    int res3 = dfs(x+1, sum + arr[x] / 2) +1;
    //不选
    int res2 = dfs(x+1, sum);
    return min({res1, res2, res3});
}

signed main(){
    cin >> n >> m;
    //在存入数据之前 将数据*2 
    //后续操作不需要使用 double
    for(int i = 1; i <= n; i++){
        int x; cin >> x;
        arr[i] = 2*x;
    }
    //将arr数组从大到小排序
    sort(arr+1, arr+n+1);reverse(arr+1, arr+n+1);
    //后缀和
    for(int i = n; i >= 1; i--){
        w[i] = w[i+1] + arr[i];
    }
    //得到答案
    int res =  dfs(1, 0);
    //判断一下 能不能买到总重量恰好为m的瓜
    if(res == N){
        cout << "-1" << endl;
    }else{
        cout << res << endl;
    }
    return 0;
}

原文地址:https://blog.csdn.net/2202_75344116/article/details/146302896
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/588326.html

相关文章:

  • 深入分析 Shell 中 IFS、数组赋值与输出行为
  • 相对论-空间和时间(1)
  • ngx_event_conf_t
  • 淘宝API vs 爬虫:合规获取实时商品数据的成本与效率对比
  • [论文阅读]Demystifying Prompts in Language Models via Perplexity Estimation
  • 前端性能优化指标及优化方案
  • Leetcode-1278.Palindrome Partitioning IV [C++][Java]
  • 重返OI:1999
  • 计算机网络:IP数据分片与偏移试题
  • 【网络安全 | 漏洞挖掘】价值14981$的Google点击劫持漏洞
  • 【Agent】OpenManus-Agent-实现具体的智能体
  • c#:使用串口通讯实现数据的发送和接收
  • [WEB开发] Web基础
  • 由一个话题进入DFMEA(设计失效模式及影响分析)
  • 关于新奇的css
  • 强化学习 - PPO控制无人机
  • 第5章 构造、析构、拷贝语义学2: 继承情况下的对象构造
  • ETIMEDOUT 网络超时问题
  • Webpack总结
  • PowerBI数据建模基础操作1:数据关系(基数、双向筛选、常规关系、有限关系)与星型架构(维度表、事实表)