• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
村雨sup
自己选的路,跪着也要走完 XD
博客园    首页    新随笔    联系   管理    订阅  订阅
dp练习(2)——老鼠的旅行

1267 老鼠的旅行(来源:codevs)

#include "bits/stdc++.h"
using namespace std;

long long dp[100][100];
int Map[100][100];

int main()
{
    memset(dp,0,sizeof(dp));
    memset(Map,0, sizeof(Map));

    int n, m;
    cin >> n >> m;
    int k;
    cin >> k;
    for(int i=1 ;i <= k;i++)
    {
        int x,y;
        cin >> x >> y;
        Map[x][y] = 1;
    }

    for(int i=1;i <= n;i++)
    {
        if(Map[i][1] == 0) dp[i][1] = 1;
        else break;
    }
    for(int i=1;i <= m;i++)
    {
        if(Map[1][i] == 0) dp[1][i] = 1;
        else break;
    }
    for(int i=2;i <= n;i++)
    {
        for(int j=2;j <= m;j++)
        {
            if(Map[i][j] == 1) dp[i][j] = 0;
            else dp[i][j] = dp[i-1][j] + dp[i][j-1];
        }
    }
    cout << dp[n][m] <<endl;

    return 0;
}

相同练习

posted on 2018-01-18 23:52  村雨sup  阅读(164)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3