SRM 658 DIV1 650 二分答案 动态规划

题目链接:暂无

题目大意:
n 个数,每次操作可以选择3个数,将其中一个数减 9 ,一个数减3,一个数减 1 ,不能减同一个数,询问最少多少次操作可以令所有数0

题解:
二分枚举答案 lim ,那么就可以将操作拆分来看,有 lim 次减 9 操作,lim次减 3 操作,lim次减 1 操作,但是对于某个数的总操作次数不能大于lim(此时这个数一定在某次操作中被同时被减)
f[i][A][B] 表示已经将 i1 个数减为非正数,还能用 A 次减9操作, B 次减3操作时剩余的最大的减 1 操作的次数
那么f[i][A][B]=max{f[i1][A+a][B+b]c}(将第 i 个数减为非正用了a次减 9 操作,b次减 3 操作,c次减 1 操作)
如果A,B0使得 f[n][A][B]0 那么 lim 可行

代码:

#include <bits/stdc++.h>
using namespace std;
class Mutalisk
{
    private:
    int n;
    int f[21][94][94];
        bool Judge(const vector<int>&x,int lim)
        {
            memset(f,-1,sizeof f);
            f[0][lim][lim]=lim;
            for(int i=1;i<=n;i++)
                for(int A=0;A<=lim;A++)
                for(int B=0;B<=lim;B++)
                    if(dp[i-1][A][B]>=0)
                        for(int a=0;a<=A;a++)
                        for(int b=0;b<=B;b++)
                        {
                            int c=max(0,x[i-1]-a*9-b*3);
                            if(a+b+c>lim) continue;
                            if(c>f[i-1][A][B]) continue;
                            f[i][A-a][B-b]=max(f[i][A-a][B-b],f[i-1][A][B]-c);
                        }
            for(int A=0;A<=lim;A++)
            for(int B=0;B<=lim;B++)
                if(f[n][A][B]>=0)
                    return 1;
            return 0;
        }
    public:
        int minimalAttacks(vector<int>x)
        {
            n=x.size();
            int l=1,r=93,re,mid;
            while(l<=r)
            {
                mid=(l+r)>>1;
                if(Judge(x,mid))
                {
                    re=mid;
                    r=mid-1;
                }
                else l=mid+1;
            }
            return re;
        }
};
利用 TensorFlow 训练自己的目标识别器。本文内容来自于我的毕业设计,基于 TensorFlow 1.15.0,其他 TensorFlow 版本运行可能存在问题。.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值