百度笔试9.20矩阵路径数目代码

用两个二维数组分别记录从左往右的前缀和,以及从上到下的前缀和,由此优化时间到O(N^2)

#include <bits/stdc++.h>
using namespace std;
#define N 2005

int dp[N][N];
int rowpre[N][N];
int colpre[N][N];
const int modval = 1e9 + 7;

int main(){
    dp[1][1] = 1;
    for(int i = 1; i <= 2000; ++i){
        for(int j = 1; j <= 2000; ++j){
            dp[i][j] += rowpre[i][j - 1] + colpre[i - 1][j];
            rowpre[i][j] = (dp[i][j] + (j - 2 > 0 ? rowpre[i][j - 2] : 0)) % modval;
            colpre[i][j] = (dp[i][j] + (i - 2 > 0 ? colpre[i - 2][j] : 0)) % modval;
        }
    }
    int t;
    cin >> t;
    int m, n;
    while(t--){
        cin >> m >> n;
        cout << dp[m][n] << endl;
    }
    return 0;
}
#百度##百度笔试##百度2023秋招笔试心得体会#
全部评论
hi~同学,秋招遇“寒气”,牛客送温暖啦!23届秋招笔面经有奖征集中,参与就得牛客会员7天免费体验,最高赢300元京东卡!戳我去看>>>https://www.nowcoder.com/link/zhengjipinglun
点赞 回复 分享
发布于 2022-09-22 10:27 北京
他说的走奇数步,如果1直接走到3,5,7,9步到下一个点这个还成立嘛,感觉这个是考虑每次走1步或者3步的情况
点赞 回复 分享
发布于 2022-09-21 19:33 黑龙江
能ac吗
点赞 回复 分享
发布于 2022-09-21 16:31 北京

相关推荐

不愿透露姓名的神秘牛友
07-08 12:10
点赞 评论 收藏
分享
06-10 21:15
门头沟学院 Java
宁阿:好多这种没🧠的公司,他们估计都不知道毕业的人不能给安排实习岗
实习吐槽大会
点赞 评论 收藏
分享
Lorn的意义:你这种岗位在中国现在要么牛马天天加班,要么关系户进去好吃好喝,8年时间,真的天翻地覆了,对于资本来说你就说一头体力更好的牛马,哎,退伍没有包分配你真的亏了。
点赞 评论 收藏
分享
评论
1
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务