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

推荐优秀的企业网站设计网上ui设计培训

推荐优秀的企业网站设计,网上ui设计培训,邯郸做网站的电话,网络媒体广告公司题目重述: 题目的核心是找到一条路径的最大权值总和,但路径要从起点 (1, 1) 走到终点 (n, n)。由于两条路径分别经过不同的格子,我们可以巧妙地将问题简化为两次同时出发的路径问题。这种映射的设计让我们能够更方便地处理两条路径重叠在同一…

题目重述:

题目的核心是找到一条路径的最大权值总和,但路径要从起点 (1, 1) 走到终点 (n, n)。由于两条路径分别经过不同的格子,我们可以巧妙地将问题简化为两次同时出发的路径问题。这种映射的设计让我们能够更方便地处理两条路径重叠在同一个格子的情况,同时简化状态的描述和转移过程。

同时出发的映射设计:

我们把两次路径的移动过程看作是两个角色同时出发并移动

  • 路径长度(步数)用 k 表示。
  • 对于某个步数 k,两个角色分别位于 (x1, y1)(x2, y2) 两个位置上。
  • 因为两条路径同时出发,满足:
    x 1 + y 1 = x 2 + y 2 = k x_1 + y_1 = x_2 + y_2 = k x1+y1=x2+y2=k
    这说明步数 k 决定了两个角色的行列位置之间的关系。

我们只需要用 3 个状态变量来描述状态:

  • k: 当前的步数(路径的长度)。
  • x1: 角色 1 在当前步数下的行位置。
  • x2: 角色 2 在当前步数下的行位置。

这样,位置 (y1)(y2) 则可以通过 y1 = k - x1y2 = k - x2 推出。

DP 状态定义:

f[k][x1][x2] 表示在步数 k 时,两个角色分别位于 (x1, y1)(x2, y2) 位置时,能达到的最大权值总和。

重叠格子的处理:
  • 两条路径走到不同的格子
    如果两个角色的行位置不同 (x1 ≠ x2),说明它们当前站在不同的格子上,则权值总和为:
    w ( x 1 , k − x 1 ) + w ( x 2 , k − x 2 ) w(x1, k - x1) + w(x2, k - x2) w(x1,kx1)+w(x2,kx2)

  • 两条路径走到相同的格子
    如果两个角色的行位置相同 (x1 = x2),说明它们当前站在同一个格子上,此时我们只加一次该格子的权值:
    w ( x 1 , k − x 1 ) w(x1, k - x1) w(x1,kx1)

状态转移:

在步数 k 时,每个角色都有两种选择:向右走向下走
这导致从 k-1 时的状态到 k 时的状态共有 4 种可能的转移路径:

f [ k ] [ x 1 ] [ x 2 ] = max ⁡ { f [ k − 1 ] [ x 1 − 1 ] [ x 2 − 1 ] , f [ k − 1 ] [ x 1 ] [ x 2 − 1 ] , f [ k − 1 ] [ x 1 − 1 ] [ x 2 ] , f [ k − 1 ] [ x 1 ] [ x 2 ] } + w f[k][x1][x2] = \max \left\{ \begin{aligned} &f[k - 1][x1 - 1][x2 - 1], \\ &f[k - 1][x1][x2 - 1], \\ &f[k - 1][x1 - 1][x2], \\ &f[k - 1][x1][x2] \end{aligned} \right\} + w f[k][x1][x2]=max f[k1][x11][x21],f[k1][x1][x21],f[k1][x11][x2],f[k1][x1][x2] +w

其中,w 的值根据上述重叠情况确定。

越界判断的必要性:

在进行状态转移时,需要保证所有涉及的状态都在合法范围内。
由于 x1x2 代表行位置,所以需要确保它们不会越过棋盘边界。
即:
1 ≤ x 1 , x 2 ≤ n 且 1 ≤ y 1 = k − x 1 ≤ n 1 ≤ y 2 = k − x 2 ≤ n 1 \leq x1, x2 \leq n \quad \text{且} \quad 1 \leq y1 = k - x1 \leq n \quad 1 \leq y2 = k - x2 \leq n 1x1,x2n1y1=kx1n1y2=kx2n
这正是代码中越界判断的由来:

if (k - i <= 0 || k - i > n || k - j <= 0 || k - j > n) continue;

这个判断确保每个角色的当前位置都在合法范围 [1, n] 之内。否则,跳过当前状态,避免数组越界访问。

DP分析

  • 初始状态
    从起点 (1, 1) 同时出发:
    f [ 2 ] [ 1 ] [ 1 ] = w ( 1 , 1 ) f[2][1][1] = w(1, 1) f[2][1][1]=w(1,1)

  • 目标状态
    当两条路径同时到达终点 (n, n),即:
    f [ 2 ∗ n ] [ n ] [ n ] f[2 * n][n][n] f[2n][n][n]
    该状态的值即为答案。

  • 过程分析

    image-20241019153958495

    IMG_623B17197D17-1.jpeg

代码

#include <iostream>
#include <algorithm> // 引入算法库以使用 std::maxusing namespace std;const int N = 15, M = 2 * N;int n;
int a, b, c;
int w[N][N];
int f[M][N][N];int main()
{cin >> n;while (cin >> a >> b >> c, a || b || c) w[a][b] += c;for (int k = 2; k <= 2 * n; ++k){for (int i = 1; i <= n; ++i){for (int j = 1; j <= n; ++j){if (k - i <= 0 || k - i > n || k - j <= 0 || k - j > n) continue;/*判断逻辑:这段判断确保两个角色的当前位置 (i, k - i) 和 (j, k - j) 是在有效的棋盘范围内。k - i <= 0:确保角色 1 的列位置不小于 1。k - i > n:确保角色 1 的列位置不大于 n(棋盘的边界)。k - j <= 0:确保角色 2 的列位置不小于 1。k - j > n:确保角色 2 的列位置不大于 n。如果任何一条路线越界,就执行 continue,跳过这一次的计算。*/int v = w[i][k - i];if (i != j) v += w[j][k - j];f[k][i][j] = max({f[k - 1][i - 1][j - 1], f[k - 1][i][j - 1], f[k - 1][i - 1][j], f[k - 1][i][j]}) + v;}}}cout << f[2 * n][n][n] << endl;return 0;
}
                f[k - 1][i][j]}) + v;}}
}cout << f[2 * n][n][n] << endl;
return 0;

}


http://www.yayakq.cn/news/783873/

相关文章:

  • 网站推广网站制作网站建设公司徐州手机网站制作公司哪家好
  • 可视方便建站微网站哪个好怎么用网址导航源码
  • 扬中网站建设服务如何选择模板网站建设
  • Apple 手机网站制作宣传册设计与制作教程
  • 蒙阴网站建设个人网页背景图片大全
  • 如何用魔方网表做门户网站网站建站智能系统
  • 网站营销的定义西安网站到首页排名
  • 网站怎么做商桥网站备案找谁
  • 做720效果的还有哪个网站婚纱设计工作室
  • 那些网站分享pr做的视频wordpress模版建站
  • 个人怎么注册自己的网站苏州网站开发建设服务
  • 专业网站建设做网站需要学jsp
  • 找我家是做的视频网站好wordpress好还是dz
  • 深圳策划公司网站美食网页设计报告
  • 车陂手机网站建设电话大型网站的mssql数据库要付费吗
  • 如何进行网络推广和宣传郑州seo网站有优化
  • 福州市建设厅网站网站建设要托管服务器
  • 专业的培训网站建设网站建设公司销售技巧
  • 广东石油化工建设集团公司网站站长统计软件
  • 外贸常用社交网站有哪些wordpress提交页面反应迟钝
  • 用凡科做的手机网站版产品开发的流程包括哪几个阶段
  • 企业网站建设 属于什么费用直播网站的建设
  • 做营销型网站 推广的好处国际域名注册流程
  • 绍兴手机网站建设什么叫网站建设四网合一
  • 建筑设计资料网站wordpress改链接
  • 营销型网站创建深圳网站定制价格表
  • 厦门哪里有做网站网站备案现场核验
  • 哈尔滨网站开发联系薇腾讯理财是什么样的做网站
  • 网站选择城市怎么做关键词快速排名怎么做
  • 游戏平台网站建设温州营销型网站建设