码迷,mamicode.com
首页 > 其他好文 > 详细

2018焦作网络赛B

时间:2018-09-16 12:24:12      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:min   bsp   return   tin   class   ||   max   turn   注意   

dp维护一下最大值与最小值,注意边界情况的判定。

 

 

 

技术分享图片
#include <iostream>
#include <cstring>

using namespace std;

const long long inf = (long long)1e18+(long long)9;
long long dp[7][1005];
long long dpx[7][1005];
int f[1005];
char s[15];

int main()
{
    int T;
//    int l;
    int n,m;
    long long k;
    long long ans;
    scanf("%d",&T);
    while(T--)
    {
        memset(dp,0,sizeof(dp));
        memset(dpx,0,sizeof(dpx));
        scanf("%d%d%lld",&n,&m,&k);
        for(int i=0;i<=m;i++)
        for(int j=0;j<=n;j++)
        {
            dp[i][j]=-inf;
            dpx[i][j]=inf;
        }
        for(int i=1;i<=n;i++)
        scanf("%d",&f[i]);
        getchar();
        scanf("%s",s);
        //for(int i=0;i<=m;i++)
        dpx[0][0]=dp[0][0]=k;
        ans=-inf;
        for(int i=1;i<=n;i++)
        {
            dpx[0][i]=dp[0][i]=k;
            for(int j = 0; j < m; j++)
            {
                dp[j+1][i]=-inf;
                dpx[j+1][i]=inf;
                if(j+1<=i-1)
                {
                    dp[j+1][i]=max(dp[j+1][i],dp[j+1][i-1]);
                    dpx[j+1][i]=min(dpx[j+1][i],dpx[j+1][i-1]);
                }
                //if(i<=j)continue;
                if(s[j]==+)
                {
                    dp[j+1][i]=max(dp[j+1][i],dp[j][i-1]+f[i]);
                    //dp[j+1][i]=max(dp[j+1][i],dpx[j][i-1]+f[i]);
                    //dpx[j+1][i]=min(dpx[j+1][i],dp[j][i-1]+f[i]);
                    dpx[j+1][i]=min(dpx[j+1][i],dpx[j][i-1]+f[i]);
                }
                if(s[j]==-)
                {
                    dp[j+1][i]=max(dp[j+1][i],dp[j][i-1]-f[i]);
                    //dp[j+1][i]=max(dp[j+1][i],dpx[j][i-1]-f[i]);
                    //dpx[j+1][i]=min(dpx[j+1][i],dp[j][i-1]-f[i]);
                    dpx[j+1][i]=min(dpx[j+1][i],dpx[j][i-1]-f[i]);
                }
                if(s[j]==*)
                {
                    dp[j+1][i]=max(dp[j+1][i],dp[j][i-1]*f[i]);
                    dp[j+1][i]=max(dp[j+1][i],dpx[j][i-1]*f[i]);
                    dpx[j+1][i]=min(dpx[j+1][i],dp[j][i-1]*f[i]);
                    dpx[j+1][i]=min(dpx[j+1][i],dpx[j][i-1]*f[i]);
                }
                if(s[j]==/&&f[i]!=0)
                {
                    dp[j+1][i]=max(dp[j+1][i],dp[j][i-1]/f[i]);
                    dp[j+1][i]=max(dp[j+1][i],dpx[j][i-1]/f[i]);
                    dpx[j+1][i]=min(dpx[j+1][i],dp[j][i-1]/f[i]);
                    dpx[j+1][i]=min(dpx[j+1][i],dpx[j][i-1]/f[i]);
                }
                if(j==m-1&&dp[j+1][i]>ans&&dp[j+1][i]!=inf&&j+1<=i)
                {
                    //cout<<i<<‘ ‘<<j<<‘ ‘<<dp[j+1][i]<<endl;
                    ans=dp[j+1][i];
                }
            }
        }
        if(ans==inf || ans==-inf)
        ans =k;
        //for()
        printf("%lld\n",ans);
    }
    return 0;
}
//0 1 2 3 4 5
View Code

 

2018焦作网络赛B

标签:min   bsp   return   tin   class   ||   max   turn   注意   

原文地址:https://www.cnblogs.com/LMissher/p/9655101.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!