zoukankan      html  css  js  c++  java
  • 小象和老鼠

    题目描述

    (S)国的动物园是一个(N*M)的网格图,左上角的坐标是((1,1)),右下角的坐标是((N,M))。小象在动物园的左上角,它想回到右下角的家里去睡觉,但是动物园中有一些老鼠,而小象又很害怕老鼠。动物园里的老鼠是彼此互不相同的。小象的害怕值定义为他回家的路径上可以看见的不同的老鼠的数量。若小象当前的位置为((x1,y1)),小象可以看见老鼠,当且仅当老鼠的位置((x2,y2))满足(|x1-x2|+|y1-y2|<=1)。由于小象很困了,所以小象只会走一条最近的路回家,即小象只会向下或者向右走。现在你需要帮小象确定一条回家的路线,使得小象的害怕值最小。

    输入格式

    第一行包含两个用空格隔开的整数,(N)(M)

    接下来一个(N*M)的矩阵表示动物园的地图。其中(A[i][j])表示第(i)行第(j)列上老鼠的数量。若(A[i][j]=0)则表示当前位置上没有老鼠(小象的家里也可能存在老鼠)。

    输出格式

    输出一个整数,表示路线最小的害怕值是多少。

    样例

    样例输入

    3 9 
    0 0 1 0 0 0 0 0 1 
    1 1 1 1 1 1 0 1 0 
    1 0 0 1 0 0 1 0 0
    

    样例输出

    9
    

    code

    #include <bits/stdc++.h>
    using namespace std;
    //动物园里的老鼠是彼此互不相同的。小象的害怕值定义为他回家的路径上可以看见的不同的老鼠的数量。!!!
    const int maxn = 1000 + 10;
    const int INF = 0x3f3f3f3f;
    int dp[maxn][maxn][2];  // 0从左方转移,1从上边转移
    int a[maxn][maxn];
    int main() {
        memset(dp, INF, sizeof(dp));
        int n, m;
        cin >> n >> m;
        for (int i = 1; i <= n; i++)
            for (int j = 1; j <= m; j++) 
                cin >> a[i][j];
        dp[1][1][1] = a[1][1] + a[1][2] + a[2][1];  //自己家里的+下方的+右边的
        dp[1][1][0] = a[1][1] + a[1][2] + a[2][1];
        for (int i = 1; i <= n; i++)
            for (int j = 1; j <= m; j++) {
                if (i == 1)
                    dp[i][j][0] = min(dp[i][j - 1][1], dp[i][j - 1][0]) + a[i + 1][j] + a[i][j + 1];
                else if (j == 1)
                    dp[i][j][1] = min(dp[i - 1][j][0], dp[i - 1][j][1]) + a[i + 1][j] + a[i][j + 1];
                else {
                    dp[i][j][1] = min(dp[i - 1][j][0], dp[i - 1][j][1] + a[i][j - 1]) + a[i + 1][j] + a[i][j + 1];
                    //如果f[i][j]的上一个点(即f[i-1][j][0])为左边即f[i-1][j-1]转移来的,那么直接转移即可,
                    //因为左边f[i][j-1]这种老鼠已经见过了,画图理解
                    //如果f[i][j]的上一个点(即f[i-1][j][1])为上边即f[i-2][j]转移来的,那么因为左边f[i][j-1]这种老鼠没见过,
                    //所以需要在加上左边f[i][j-1]这种老鼠
                    dp[i][j][0] = min(dp[i][j - 1][1], dp[i][j - 1][0] + a[i - 1][j]) + a[i + 1][j] + a[i][j + 1];
                    //动物园里的老鼠是彼此互不相同的。小象的害怕值定义为他回家的路径上可以看见的不同的老鼠的数量。!!!
                }
            }
        return cout << min(dp[n][m][0], dp[n][m][1]) << endl, 0;
    }
    
  • 相关阅读:
    【Codeforces 776B】Sherlock and his girlfriend
    BZOJ4942 NOI2017整数(线段树)
    BZOJ4516 SDOI2016生成魔咒(后缀数组+平衡树)
    BZOJ4943 NOI2017蚯蚓排队(哈希+链表)
    Codeforces Round#500 Div.2 翻车记
    BZOJ5093 图的价值(NTT+斯特林数)
    BZOJ2821 作诗(分块)
    BZOJ2724 [Violet]蒲公英(分块)
    BZOJ2001 HNOI2010城市建设(线段树分治+LCT)
    BZOJ1093 ZJOI2007最大半连通子图(缩点+dp)
  • 原文地址:https://www.cnblogs.com/hellohhy/p/13280331.html
Copyright © 2011-2022 走看看