• hdu1224 dp


    #include<stdio.h>
    #include<string.h>
    #define maxn 105
    int a[maxn],dp[maxn],map[maxn][maxn],pre[maxn];
    int max(int x,int y)
    {
        return x>y?x:y;
    }
    void print(int p)
    {
        if(p==1)//一定从1点出发
        {
            printf("1");
            return ;
        }
        print(pre[p]);
        printf("->%d",p);
    }
    int main()
    {
        int i,j,t,n,m,ff=0;
        scanf("%d",&t);
        while(t--)
        {
            scanf("%d",&n);
            for(i=1;i<=n;i++)
            {
                scanf("%d",&a[i]);
            }
            a[n+1]=0;
            scanf("%d",&m);
            memset(dp,0,sizeof(dp));
            memset(map,0,sizeof(map));
            for(i=1;i<=m;i++)
            {
                int x,y;
                scanf("%d%d",&x,&y);
                map[x][y]=1;
            }
            for(i=1;i<=n+1;i++)
            {
                for(j=1;j<=n+1;j++)
                {
                    if(map[i][j]&&dp[j]<dp[i]+a[j])//到j点的值要大
                    {
                        dp[j]=dp[i]+a[j];
                        pre[j]=i;
                    }
                }
            }
            printf("CASE %d#
    ",++ff);
            printf("points : %d
    ",dp[n+1]);
            printf("circuit : ");
            print(pre[n+1]);
            printf("->1
    ");
            if(t!=0)
                printf("
    ");
        }
    }
  • 相关阅读:
    防御式编程
    Linux磁盘与文件系统管理
    更加抽象
    高质量的子程序
    Linux文件与目录管理
    抽象
    可以工作的类
    Linux的文件权限与目录配置
    条件、循环和其他语句
    软件构建中的设计
  • 原文地址:https://www.cnblogs.com/sweat123/p/4760991.html
Copyright © 2020-2023  润新知