ZOJ 3735 Josephina and RPG (dp)

这题应该是动态规划吧,乱猜的。

dp[i][j]表示 开始的时候选择第i个人。后来经过战斗&交换变成第j个人。的最优值。

#pragma comment(linker, "/STACK:1024000000,1024000000")
#include <cstdio>
#include <cmath>
#include <cstring>
#include <iostream>
#include <queue>
#include <map>
#include <stack>
#include <string>
#include <algorithm>
#include <vector>
#include <list>
#include <deque>

#define LL long long
#define DB double
#define SI(a) scanf("%d",&a)
#define SD(a) scanf("%lf",&a)
#define SS(a) scanf("%s",a)
#define PF printf
#define MM(a,b) memset(a,b,sizeof(a))
#define REP(i,a,b) for(int i=a;i<b;i++) 
#define REPD(i,a,b) for(int i=a;i>b;i--)
#define INF 0x3f3f3f3f
#define EPS 1e-8
#define bug puts("bug")
using namespace std;
#define N 129
DB re[N][N];
DB dp[N][N];
int n,m;
int main()
{
    #ifndef ONLINE_JUDGE
    freopen("in.txt","r",stdin);
    #endif
    int a;
    while(~SI(n)) {
        n = n*(n-1)*(n-2)/6;
        REP(i,0,n) 
            REP(j,0,n) SD(re[i][j]);
        SI(m);
        REP(i,0,n)
            REP(j,0,n) dp[i][j] = -1;
        REP(i,0,n) dp[i][i] = 1;
        while(m--) {
            SI(a);
            DB tmp = -1;
            REP(i,0,n) {
                tmp = -1;
                REP(j,0,n)
                if(dp[i][j]>=0) {
                    tmp = max(tmp,dp[i][j]=dp[i][j]*re[j][a]);
                }
                dp[i][a] = tmp;
            }
        }
        DB ans = -1;
        REP(i,0,n) ans = max(ans,dp[i][a]);
        PF("%.7lf\n",ans);
    }
    return 0;
}


阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页