当前位置: 首页 > wzjs >正文

哪些网站可以接任务做兼职网站设计师发展方向

哪些网站可以接任务做兼职,网站设计师发展方向,如何给一个网站做优化,.net程序员网站开发工程师洛谷P1002 [NOIP 2002 普及组] 过河卒 题解 题目描述 过河卒是一道经典的动态规划题目。题目大意是:一个卒子从棋盘左上角(0,0)出发,要走到右下角(n,m),棋盘上有一个马在(x,y)位置,卒子不能经过马所在位置及其周围8个位置。求卒…

洛谷P1002 [NOIP 2002 普及组] 过河卒 题解

题目描述

过河卒是一道经典的动态规划题目。题目大意是:一个卒子从棋盘左上角(0,0)出发,要走到右下角(n,m),棋盘上有一个马在(x,y)位置,卒子不能经过马所在位置及其周围8个位置。求卒子的合法路径总数。

解题思路

1. 问题分析

  • 棋盘范围:棋盘为(n+1)×(m+1)的网格(坐标从0开始)
  • 移动规则:卒子只能向右或向下移动
  • 阻挡条件:马的位置及其控制的8个位置不可达
  • 核心目标:统计从起点到终点的所有合法路径数

2. 动态规划建模

状态定义

dp[i][j]表示从起点(0,0)到达坐标(i,j)的合法路径总数

状态转移

d p [ i ] [ j ] = { 0 当前位置被马控制 1 i=0且j=0(起点) d p [ i − 1 ] [ j ] + d p [ i ] [ j − 1 ] 其他情况 dp[i][j] = \begin{cases} 0 & \text{当前位置被马控制} \\ 1 & \text{i=0且j=0(起点)} \\ dp[i-1][j] + dp[i][j-1] & \text{其他情况} \end{cases} dp[i][j]= 01dp[i1][j]+dp[i][j1]当前位置被马控制i=0j=0(起点)其他情况

初始化条件
  • dp[0][0] = 1(起点自身算1条路径)
  • 被马控制的位置及其后续位置保持0值

3. 关键优化

坐标系偏移

将原始坐标系整体右移2格,下移2格(代码中b1 += 2; b2 += 2),目的是:

  1. 避免处理负数坐标
  2. 统一处理棋盘边界(通过循环条件i <= b1j <= b2自动限制范围)
马控制范围判断

通过预定义的8个方向向量:

int dx[8] = {-2,-2,-1,+1,+2,+2,+1,-1};
int dy[8] = {-1,+1,+2,+2,+1,-1,-2,-2};

检查目标位置是否被马控制:

bool pd(int a, int b) {// 检查马本体位置if (m1 == a && m2 == b) return false;// 检查8个控制位for (int i = 0; i < 8; ++i) {if (m1 + dx[i] == a && m2 + dy[i] == b) return false;}return true;
}

代码解析

1. 输入处理

cin >> b1 >> b2 >> m1 >> m2;
b1 += 2;  // 扩展后的棋盘行数
b2 += 2;  // 扩展后的棋盘列数
m1 += 2;  // 马坐标同步偏移
m2 += 2;

2. 动态规划核心

for (int i = 2; i <= b1; ++i) {        // 遍历所有行for (int j = 2; j <= b2; ++j) {    // 遍历所有列if (!pd(i, j)) {               // 被马控制的位置dp[i][j] = 0;continue;}if (i == 2 && j == 2) {        // 起点初始化dp[i][j] = 1;continue;}dp[i][j] = dp[i-1][j] + dp[i][j-1];  // 状态转移}
}

3. 输出结果

最终结果存储在dp[b1][b2]中,直接输出即可。

复杂度分析

  • 时间复杂度:O(nm),仅需遍历棋盘一次
  • 空间复杂度:O(nm),使用二维数组存储状态

常见错误及注意事项

  1. 坐标偏移:忘记对马的位置进行同步偏移会导致控制范围判断错误
  2. 边界条件:当马位于起点或终点时,路径数应为0
  3. 数据类型:路径数可能超过int范围,需使用long long类型
  4. 初始化顺序:必须按行优先顺序填充dp数组,保证状态转移的正确性

扩展思考

  • 记忆化搜索:可用DFS+记忆化实现,但时间复杂度较高(O(2^(n+m)))
  • 矩阵快速幂:对于无阻挡的纯路径计数问题,可用组合数学优化到O(log(n+m))
  • 三维DP:当需要记录更多状态时(如不同移动方式),可扩展DP维度

总结

本题通过动态规划完美解决了路径计数问题,关键点在于:

  1. 合理建模状态转移方程
  2. 正确处理棋盘边界和阻挡条件
  3. 通过坐标偏移简化边界判断

该方法的时间复杂度稳定在O(nm),能够高效处理题目给定的数据范围(n,m ≤ 20),是典型的动态规划应用案例。


文章转载自:

http://uSqStc4C.gmrxh.cn
http://kMOLO0XG.gmrxh.cn
http://pgERixF4.gmrxh.cn
http://PLBVAzx4.gmrxh.cn
http://ww6afIew.gmrxh.cn
http://N8boWTUz.gmrxh.cn
http://y52AYBfH.gmrxh.cn
http://PN1dwhUc.gmrxh.cn
http://10ZRzT8M.gmrxh.cn
http://dJu9K8wR.gmrxh.cn
http://oJzkJaW5.gmrxh.cn
http://qh1lvk42.gmrxh.cn
http://7wd5yz9D.gmrxh.cn
http://CtlwTtaE.gmrxh.cn
http://wqfwtcA1.gmrxh.cn
http://aRWBEFAN.gmrxh.cn
http://nMsSx5pk.gmrxh.cn
http://CukckJeq.gmrxh.cn
http://e9Tmql7f.gmrxh.cn
http://K1ziY1Oe.gmrxh.cn
http://LoB5JmIa.gmrxh.cn
http://8gJ4TAKm.gmrxh.cn
http://7rHNcXth.gmrxh.cn
http://MZg8M3QL.gmrxh.cn
http://Ei0JCmsl.gmrxh.cn
http://LVck4BEE.gmrxh.cn
http://8ZPdkdgk.gmrxh.cn
http://y1JXA0aC.gmrxh.cn
http://w76zkHtr.gmrxh.cn
http://9FPVPbOH.gmrxh.cn
http://www.dtcms.com/wzjs/632334.html

相关文章:

  • 安徽网站优化建设qq空间网站根目录
  • 百度网站改版工具2023太原封控最新消息查询
  • 贵州省铜仁市城乡建设局网站世界网站制作
  • 张家港建设局网站豪华网站设计
  • 南京响应式网站设计wordpress 搜索 多个词
  • 网站托管费用 优帮云常州低价网站建设公司
  • 青岛网站建设推广公司市场调研的四个步骤
  • 网络网站小程序助手官网
  • 互联网高端官网广州网站优化关键词方法
  • 扫描网站特征dede网站内页怎么做seo
  • 南通网站建设入门加强网站建设的通知
  • 网站建设九亭网营科技是外包公司吗
  • 网上购物最实惠的网站整合营销策划名词解释
  • 想自己做网站 有免费的吗满洲里建设局网站
  • 什么网站需要icp备案263企业邮箱管理员登录入口
  • 如何选择镇江网站建设网站建设的重要性
  • 网站建设接私活平台用手机制作视频的软件
  • 做公司网站的模板门户 diy WordPress
  • 做内贸的网站网站优化标题
  • 松江做移动网站厦门网站搜索引擎优化
  • 届毕业设计代做网站ps网页设计培训班
  • 网站开发h5页面seo这个行业怎么样
  • 网站后台如何登录天津住房和城乡建设部网站
  • 北京模板网站建设费用网站开发公司按时交付
  • 全国可信网站网站运营需要哪些资质
  • 体育门户网站源码appcan wordpress
  • 做网站可以用哪些语言简洁大气摄影网站
  • 乡镇信息公开网站建设制度学什么专业可以做网站
  • 做网站的业务员网站推广费用一般多少钱
  • 阿里巴巴做网站费用计入wordpress 模板使用