首页 > 其他分享 >洛谷题单指南-搜索-P2392 kkksc03考前临时抱佛脚

洛谷题单指南-搜索-P2392 kkksc03考前临时抱佛脚

时间:2024-03-04 17:00:45浏览次数:25  
标签:maxx P2392 int 洛谷题 dfs INT ans path kkksc03

原题链接:https://www.luogu.com.cn/problem/P2392

解题思路:参考https://www.cnblogs.com/jcwy/p/18003097

前面已经给出了二进制法的代码,这里给出DFS的代码

100分代码:

#include <bits/stdc++.h>
using namespace std;

const int N = 25;

int s1, s2, s3, s4;
int a[N], b[N], c[N], d[N];
int path[N];
int ans, maxx = INT_MIN, minx = INT_MAX; //ans是最终答案,tmp是计算每一科所需要的最少时间

//枚举所有的子集,计算子集和与剩余元素和之差的绝对值最小时,较大的那一组元素和
//所有path[i]=1的课程分为一组,所有path[i]=0的分为一组
void dfs(int e[N], int len, int k)
{
    if(k > len) //找到一个划分方法
    {
        int sum1 = 0, sum2 = 0; //sum1是path[i]=1的课程消耗时间之和,sum2是path[i]=0的课程消耗时间之和
        for(int i = 1; i <= len; i++)
        {
            if(path[i] == 1) sum1 += e[i];
        }
        sum2 = e[0] - sum1;
        if(abs(sum1 - sum2) < minx)
        {
            minx = abs(sum1 - sum2);
            maxx = max(sum1, sum2);
        }
        return;
    }

    path[k] = 0;
    dfs(e, len, k + 1);
    
    path[k] = 1;
    dfs(e, len, k + 1);
}

int main()
{
    cin >> s1 >> s2 >> s3 >> s4;
    for(int i = 1; i <= s1; i++) 
    {
        cin >> a[i];
        a[0] += a[i]; //a[0]是元素之和
    }
    for(int i = 1; i <= s2; i++) 
    {
        cin >> b[i];
        b[0] += b[i]; //b[0]是元素之和
    }
    for(int i = 1; i <= s3; i++) 
    {
        cin >> c[i];
        c[0] += c[i]; //c[0]是元素之和
    }
    for(int i = 1; i <= s4; i++) 
    {
        cin >> d[i];
        d[0] += d[i]; //d[0]是元素之和
    }
    
    dfs(a, s1, 1); 
    ans += maxx; maxx = INT_MIN; minx = INT_MAX;
    dfs(b, s2, 1); 
    ans += maxx; maxx = INT_MIN; minx = INT_MAX;
    dfs(c, s3, 1); 
    ans += maxx; maxx = INT_MIN; minx = INT_MAX;
    dfs(d, s4, 1); 
    ans += maxx;
    cout << ans;

    return 0;
}

 

标签:maxx,P2392,int,洛谷题,dfs,INT,ans,path,kkksc03
From: https://www.cnblogs.com/jcwy/p/18052141

相关文章

  • 洛谷题单指南-搜索-P1219 [USACO1.5] 八皇后 Checker Challenge
    原题链接:https://www.luogu.com.cn/problem/P1219题意解读:八皇后,经典回溯问题。解题思路:逐行摆放棋子,关键在于如何快速判断行、列、正斜(左上到右下)、反斜(右上到左下)方向没有已放其他棋子1、由于逐行摆放,因此行不需要判断通过一个boolcol[N]数组即可判断列上是否已摆放其他棋......
  • 洛谷题单指南-二分查找与二分答案-P3743 kotori的设备
    原题链接:https://www.luogu.com.cn/problem/P3743题意解读:设备使用的时间越久,需要充电的总时间也越多,具备单调性,根据使用的时间,计算需要充电的时间,如果充电总时间<=使用的时间,说明有电量还能富余,使用时间还可以更多,因此只需对使用时间进行二分即可。解题思路:给定设备使用的时间......
  • 洛谷题单指南-二分查找与二分答案-P1163 银行贷款
    原题链接:https://www.luogu.com.cn/problem/P1163题意解读:利率越小,贷款期限和每个月还的钱固定的情况下,越有可能能够还完全部的贷款,具备单调性,因此给定贷款利率、贷款月数、每月还款钱数,可以计算最终贷款还剩下多少,有两种情况:>=0,说明利率可能大了,要试探更小利率;<0,说明利率小了,要......
  • 洛谷题单指南-二分查找与二分答案-P1182 数列分段 Section II
    原题链接:https://www.luogu.com.cn/problem/P1182题意解读:每段和的最大值越小,则分段数就越多,因此可以通过给定每段和的最大值,将分段数划分为两类:<=M,>M,对每段和的最大值进行二分即可。解题思路:二分的判定条件为,给定每段和的最大值,计算分段数,计算逻辑如下:依次遍历每一个数,求当前......
  • 洛谷题单指南-二分查找与二分答案-P3853 [TJOI2007] 路标设置
    原题链接:https://www.luogu.com.cn/problem/P3853题意解读:相邻路标的最大距离即空旷指数,空旷指数越小,用的路标越多,因此可以根据空旷指数将使用路标情况分成两类:路标数<=K,路标数>K,对空旷指数进行二分即可。解题思路:二分的判定条件为,给定空旷指数,计算需要的路标数只需遍历每两......
  • 洛谷题单指南-二分查找与二分答案-P2678 [NOIP2015 提高组] 跳石头
    原题链接:https://www.luogu.com.cn/problem/P2678题意解读:最短跳跃距离越大,要移走的石头就越多,因此可以根据最短跳跃距离的不同把情况分为两类:移走的石头数<=M、移走的石头数>M,对最短跳跃距离二分即可。解题思路:二分的判定条件如下:对于给定最短跳跃距离,需要计算移走的石头数,......
  • 洛谷题单指南-二分查找与二分答案-P2440 木材加工
    原题链接:https://www.luogu.com.cn/problem/P2440题意解读:切出来的长度越短,则段数越多,可以通过二分长度来解决。解题思路:二分的关键在于判定条件,此题就是对二分到的长度计算可以切割的段数,如果段数大于等于k,则满足要求,可以继续加大长度。注意点:1、计算切割出来的段数是累加:每......
  • 洛谷题单指南-二分查找与二分答案-P1678 烦恼的高考志愿
    原题链接:https://www.luogu.com.cn/problem/P1678题意解读:要计算不满意度之和的最小值,就要保证每个人的不满意度最小,即选择的学校录取分数-学生分数之差的绝对值最小。解题思路:如何在学校录取分数中找与学生分数最接近的呢?有三种可能:1、学生分数在录取分数中存在相等的2、学......
  • 洛谷题单指南-二分查找与二分答案-P1102 A-B 数对
    原题链接:https://www.luogu.com.cn/problem/P1102题意解读:寻找A-B=C的数对数量,C大于0,B一定比A小,枚举B,找A是否存在即可。解题思路:先将数据由小到大排序,接下来介绍两种方法:二分、双指针1、二分枚举第1~n-1个数,作为B,寻找A=B+C的数量,只需要通过二分查找第一A和最后一个A的位置l、......
  • 洛谷题单指南-二分查找与二分答案-P2249 【深基13.例1】查找
    原题链接:https://www.luogu.com.cn/problem/P2249题意解读:找有序数组中某个数第一次出现的位置,二分模版题,由于是二分板块的第一题,有必要对二分的各种模版进行介绍。解题思路:关于二分的一切:1、二分的本质二分的本质,是通过某种判定把目标范围划分成两个区间二分问题通常有两......