CH Round #53—密室

CH Round #53—密室

题目

有N个密室,3种钥匙(红色,绿色,白色)和2种锁(红色,绿色),红色钥匙只能开红色的锁,绿色钥匙只能开绿色的锁,白色钥匙可以开红色的锁和绿 色的锁,一把钥匙使用一次之后会被扔掉。每个密室由一扇门锁着,上面锁着一些红色和绿色的锁,房间里面放着一些红色、绿色和白色的钥匙,打开密室你将拿走 这些钥匙。你可以以任意顺序打开密室,但是同一个密室只能打开一次。初始你已经有了一些钥匙了,现在你要进行决策,使得最终剩下的钥匙尽量的多,注意,你 不一定要打开所有的房间,你可以在任意时刻结束。输出你最多能有几把钥匙。

输入格式

第一行一个整数N,表示有N个密室。
第二行N个整数,第i个数表示第i扇门上有ai把红色的锁。
第三行N个整数,第i个数表示第i扇门上有bi把绿色的锁。
第四行N个整数,第i个数表示第i个密室有ci把红色的钥匙。
第五行N个整数,第i个数表示第i个密室有di把绿色的钥匙。
第六行N个整数,第i个数表示第i个密室有ei把白色的钥匙。
第七行三个整数k0,k1,k2,依次表示初始你拥有的红色、绿色、白色钥匙的数量。

输出格式

输出一个整数,表示你最多能有几把钥匙。

样例输入

3
1 2 3
0 4 9
0 0 10
0 8 9
1 0 8
3 1 2

样例输出

8

题解

状压dp
f[i][j]表示经过门的集合为i,红钥匙数为 j 时白钥匙最多有多少
因为我们要尽量多用红绿钥匙,可以打开更多的门,有更多的选择

代码

#include<cstring>
#include<cstdio>
#include<iostream>
#define fo(i,n) for(int i=0;i<n;i++)
using namespace std;
const int N=15;
int dR[N],dG[N],rR[N],rG[N],rW[N],ky[N],n,f[20000][200],z;
int main()
{
    scanf("%d",&n);
    fo(i,n) cin>>dR[i];
    fo(i,n) cin>>dG[i];
    fo(i,n) cin>>rR[i];
    fo(i,n) cin>>rG[i];
    fo(i,n) cin>>rW[i];
    cin>>ky[0]>>ky[1]>>ky[2];
    int sum=ky[0]+ky[1]+ky[2];
    memset(f,-1,sizeof f);
    f[0][ky[0]]=ky[2];
    fo(i,1<<n){
        int k0=ky[0],k1=ky[1],r=sum;
        fo(j,n)
            if(i>>j&1){
                k0+=rR[j];
                r+=rR[j]+rG[j]+rW[j]-dR[j]-dG[j];
            }
        for(int j=0;j<=k0;j++){
            if(f[i][j]==-1) continue;
            int fr=f[i][j];
            int k=r-fr-j;
            fo(l,n){
                if(i>>l&1) continue;
                int r=max(0,dR[l]-j),g=max(0,dG[l]-k);
               int &q=f[i|(1<<l)][max(0,j-dR[l])+rR[l]];
                if(fr>=r+g)
                    q=max(q,fr-r-g+rW[l]);
           }
            z=max(z,j+k+fr);
        }
    }
    cout<<z<<endl;
}
基于SSM框架的智能家政保洁预约系统,是一个旨在提高家政保洁服务预约效率和管理水平的平台。该系统通过集成现代信息技术,为家政公司、家政服务人员和消费者提供了一个便捷的在线预约和管理系统。 系统的主要功能包括: 1. **用户管理**:允许消费者注册、登录,并管理他们的个人资料和预约历史。 2. **家政人员管理**:家政服务人员可以注册并更新自己的个人信息、服务类别和服务时间。 3. **服务预约**:消费者可以浏览不同的家政服务选项,选择合适的服务人员,并在线预约服务。 4. **订单管理**:系统支持订单的创建、跟踪和管理,包括订单的确认、完成和评价。 5. **评价系统**:消费者可以在家政服务完成后对服务进行评价,帮助提高服务质量和透明度。 6. **后台管理**:管理员可以管理用户、家政人员信息、服务类别、预约订单以及处理用户反馈。 系统采用Java语言开发,使用MySQL据库进行据存储,通过B/S架构实现用户与服务的在线交互。系统设计考虑了不同用户角色的需求,包括管理员、家政服务人员和普通用户,每个角色都有相应的权限和功能。此外,系统还采用了软件组件化、精化体系结构、分离逻辑和据等方法,以便于未来的系统升级和维护。 智能家政保洁预约系统通过提供一个集中的平台,不仅方便了消费者的预约和管理,也为家政服务人员提供了一个展示和推广自己服务的机会。同时,系统的后台管理功能为家政公司提供了强大的据支持和决策辅助,有助于提高服务质量和管理效率。该系统的设计与实现,标志着家政保洁服务向现代化和网络化的转型,为管理决策和控制提供保障,是行业发展中的重要里程碑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

袋装猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值