hdu 2571 G++

# include <stdio.h>

int a[25][1010], vis[25][1010] ;
int n, m, INF = 0x0f0f0f0f ;

int max(int a, int b){return a>b?a:b;}

int dfs(int x, int y)
{
    int i, rtn = -INF ;
    if (x == n && y == m) return a[x][y] ;
    if (vis[x][y] != INF) return vis[x][y] ;//  访问

    if (x < n) rtn = max(rtn, dfs(x+1, y)) ;
    if (y < m) rtn = max(rtn, dfs(x, y+1)) ;

    for (i = y * 2 ; i <= m ; i+=y)
        rtn = max(rtn, dfs(x, i)) ;

    return vis[x][y] = rtn + a[x][y] ;  //原有的  +  该点的
}

int main ()
{
    int T, i, j ;
    scanf ("%d", &T) ;
    while (T--)
    {
        scanf ("%d%d", &n, &m) ;
        for (i = 1 ; i <=n ; i++)
            for (j = 1 ; j <= m ; j++)
            {
                vis[i][j] = INF ;             // 没有访问过 ,,标记
                scanf ("%d", &a[i][j]) ;
            }
        printf ("%d\n", dfs(1,1)) ;
    }
    return 0 ;
}

# include <stdio.h>

int a[25][1010], vis[25][1010] ;
int n, m, INF = 0x0f0f0f0f ;

int max(int a, int b){return a>b?a:b;}

int dfs(int x, int y)
{
    int i, rtn = -INF ;
    if (x == n && y == m) return a[x][y] ;
    if (vis[x][y] != INF) return vis[x][y] ;//  访问
   
    if (x < n) rtn = max(rtn, dfs(x+1, y)) ;
    if (y < m) rtn = max(rtn, dfs(x, y+1)) ;
   
    for (i = y * 2 ; i <= m ; i+=y)
        rtn = max(rtn, dfs(x, i)) ;

return vis[x][y] = rtn + a[x][y] ;  //原有的  +  该点的
}

int main ()
{
    int T, i, j ;
    scanf ("%d", &T) ;
    while (T--)
    {
        scanf ("%d%d", &n, &m) ;
        for (i = 1 ; i <=n ; i++)
            for (j = 1 ; j <= m ; j++)
            {
                vis[i][j] = INF ;             // 没有访问过 ,,标记
                scanf ("%d", &a[i][j]) ;
            }
        printf ("%d\n", dfs(1,1)) ;
    }
    return 0 ;
}

hdu 2571 G++

时间: 2024-08-24 17:25:39

hdu 2571 G++的相关文章

HDU 2571 命运 (DP)

命运 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Practice HDU 2571 Description 穿过幽谷意味着离大魔王lemon已经无限接近了! 可谁能想到,yifenfei在斩杀了一些虾兵蟹将后,却再次面临命运大迷宫的考验,这是魔王lemon设下的又一个机关.要知道,不论何人,若在迷宫中被困1小时以上,则必死无疑! 可怜的yifenfei为了去

HDU 2571 命运 (动规)

命运 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 9334    Accepted Submission(s): 3289 Problem Description 穿过幽谷意味着离大魔王lemon已经无限接近了! 可谁能想到,yifenfei在斩杀了一些虾兵蟹将后,却再次面临命运大迷宫的考验,这是魔王lemon设下的又一个机关.要知

hdu 2571

命运 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 9205    Accepted Submission(s): 3250 Problem Description 穿过幽谷意味着离大魔王lemon已经无限接近了!可谁能想到,yifenfei在斩杀了一些虾兵蟹将后,却再次面临命运大迷宫的考验,这是魔王lemon设下的又一个机关.要知道,

hdu 2571 命运(递推,请小心)

题目 //不能广搜,会超内存//可以用dp思想模拟//map 后来保存的是 保存由前面推来的最大的幸运总值的点//下标从1开始,不然倍数会有问题 //AC 代码: AC代码 //不能广搜,会超内存 //可以用dp思想模拟 //map 后来保存的是 保存由前面推来的最大的幸运总值的点 //下标从1开始,不然倍数会有问题 //又错了那么多次... //重写... //求过!!! #include<stdio.h> #include<string.h> #include<algor

HDU 2571 命运 简单的DP

题目链接  ~~   http://acm.hdu.edu.cn/showproblem.php?pid=2571 题意很简单,就是求左上角到右下角的最大值. 刚开始忘了初始化..WA好几回.. 代码:: 1 #include <iostream> 2 #include <cstdio> 3 using namespace std; 4 #define max(a,b) (a>b?a:b) 5 int main() 6 { 7 int map[25][1005]; 8 int

HDU 2571 命运

命运 Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID: 257164-bit integer IO format: %I64d      Java class name: Main 穿过幽谷意味着离大魔王lemon已经无限接近了!可谁能想到,yifenfei在斩杀了一些虾兵蟹将后,却再次面临命运大迷宫的考验,这是魔王lemon设下的又一个机关.要知道,不论何人,若在迷

hdu 2571 命运 (递推)

http://acm.hdu.edu.cn/showproblem.php?pid=2571 思路: dp[i+1][j]=max(dp[i+1][j],dp[i][j]+mat[i+1][j]); dp[i][j+1]=max(dp[i][j+1],dp[i][j]+mat[i][j+1]); k=2; while(k*j<=m) { dp[i][k*j]=max(dp[i][k*j],dp[i][j]+mat[i][k*j]); k++; } #include<cstdio> #in

hdu 2571 dp入门题

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2571 常规dp,刚好让我这菜鸟来找找 找状态转移方程的感觉.. 定义dp[i][j]  表示的是第i行j列所拥有的最大的幸运值. dp[i][j] 由三种情况转移而来:1.从上面一个坐标转移而来,即dp[i-1][j] .2.由左边转移过来,即dp[i][j-1].3.由他同一行中的 j 的因数列转移过来的(但是要除了j自己),即dp[i][ j 的因数列] 找出这三种情况中最大的就可以了,dp[i

HDU 动态规划 G

Problem G Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submission(s) : 43   Accepted Submission(s) : 11 Problem Description: 都说天上不会掉馅饼,但有一天gameboy正走在回家的小径上,忽然天上掉下大把大把的馅饼.说来gameboy的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的10