D—Match Stick Game (dp)2019南昌网络赛

题目链接:哆啦A梦传送门

题意:给出 0~9 十个数字,每个数字都由一些数量的火柴棒构出,现在给你一个表达式,你可以移动一些火柴棒使得这个表达式的值最大,但是要保证新的表达式的操作符与每个数字的位数要和原来的一模一样,最后输出最大表达式的值。

 

题解:参考博客:神犇

我只是加了点注释,方便自己以后回顾。

 

先预处理:

val[i][j][0] 表示位数为i,火柴棒为j的最小值
val[i][j][1] 表示位数为i,火柴棒为j的最大值

 

接着设 dp[i][j]表示前i个数字剩余j条火柴棒数量的最大值。

 

#include<bits/stdc++.h>

using namespace std;

typedef long long LL;
#define INF 0x3f3f3f3f

///val[i][j][0] 表示位数为i,火柴棒为j的最小值
///val[i][j][1] 表示位数为i,火柴棒为j的最大值
LL val[15][75][2];

///dp[i][j]表示前i个,剩余火柴棒为j的最大值
LL dp[110][710];

int num[10]={6,2,5,5,4,5,6,3,7,6};

void init()
{

    for(int i=0;i<=12;i++)
        for(int j=0;j<=72;j++)
        val[i][j][1]=-1e10,val[i][j][0]=INF;

    val[0][0][0]=val[0][0][1]=0;

    for(int i=1;i<=10;i++)///位数
    {
        ///i*7是因为一位数最多有7条火柴棒
        for(int j=1;j<=i*7;j++) ///可使用的火柴棒数
        {
            for(int k=0;k<=9;k++){ ///变换的数字

                if(j<num[k]) continue;
            val[i][j][0]=min(val[i][j][0],val[i-1][j-num[k]][0]*10+k);
            val[i][j][1]=max(val[i][j][1],val[i-1][j-num[k]][1]*10+k);
            
            }
        }
    }


}

char op[110];

///存储每个操作符op前面的数字的位数
int pre[110],cnt;///cnt表示有多少个数字
int main()
{

    int ncase,n;
    cin>>ncase;
    init();

    while(ncase--)
    {
        cin>>n>>op;
//        cout<<op<<endl;

        int len=strlen(op);

        ///last记录前一个字符的位置
        int last=-1,tot=0;
        cnt=0;
        for(int i=0;i<len;i++)
        {
            if(op[i]=='+'||op[i]=='-'){
                pre[++cnt]=i-last-1;
                last=i;
            }

            if(op[i]=='+') tot+=2;
            else if(op[i]=='-') tot++;
            else tot+=num[op[i]-'0'];
        }
        pre[++cnt]=len-last-1;

//        printf("tot=%d\n",tot);

        for(int i=0;i<=n;i++)
            for(int j=0;j<=n*7;j++)
            dp[i][j]=-1e12;

        int item=min(pre[1]*7,tot);
        for(int i=1;i<=item;i++){
            dp[1][tot-i]=max(dp[1][tot-i],val[pre[1]][i][1]);
//            printf("%lld\n",dp[1][tot-i]);
        }

        ///第几个数字
        for(int i=2;i<=cnt;i++)
        {
            ///枚举火柴棒的数量
            for(int j=0;j<=tot;j++)
            {
                item=min(pre[i]*7+2,j);
                for(int k=2;k<=item;k++)///可使用的火柴棒数
                {

                    ///要么减去最小值,要么加上最大值
            dp[i][j-k]=max(dp[i][j-k],dp[i-1][j]-val[pre[i]][k-1][0]);
            dp[i][j-k]=max(dp[i][j-k],dp[i-1][j]+val[pre[i]][k-2][1]);
                }
            }
        }

        printf("%lld\n",dp[cnt][0]);
    }

    return 0;



}

/*
tot=5
-10000000000
1
7
4
5
*/

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值