博客
关于我
Codeforces Round #459 (Div. 1) B. MADMAX(博弈+DP+记忆化搜索)
阅读量:390 次
发布时间:2019-03-05

本文共 1328 字,大约阅读时间需要 4 分钟。

代码展示了一个用于图论问题的深度优先搜索(DFS)算法,采用记忆化搜索技术来优化性能。代码定义了一个三维数组dp,其中dp[i][j][k]表示在节点i作为先手,节点j作为后手,边权为k的情况下,当前玩家是否能够获胜。通过递归函数dfs,算法对每个状态进行分析并存储结果。代码的核心逻辑是遍历每个节点的所有邻接点,对于每个邻接点,检查其边权是否满足当前轮的要求,并递归调用dfs函数判断对手是否处于劣势。如果对手无法获胜,则当前玩家可以获胜,否则无法获胜。代码的初始化部分读取输入数据,构建图的邻接表,并通过调用dfs函数对所有可能的状态进行计算。最终,代码输出每个节点对应的胜负结果,若dp[i][j][0]为0则表示先手无法获胜,否则先手可以获胜。

#include #include 
using namespace std;const int maxn = 150;int dp[maxn][maxn][maxn];vector
> g[maxn];char c;int dfs(int x, int y, int now) { if (dp[x][y][now] >= 0) return dp[x][y][now]; for (auto it : g[x]) { if (it.second >= now && dfs(y, it.first, it.second) == 0) { dp[x][y][now] = 1; return 1; } } dp[x][y][now] = 0; return 0;}int main() { int n, m; scanf("%d%d", &n, &m); for (int i = 1; i <= m; ++i) { int u, v; char c; scanf("%d%d", &u, &v); scanf("%c", &c); g[u].push_back({v, c}); } memset(dp, -1, sizeof(dp)); for (int i = 1; i <= n; ++i) { for (int j = 1; j <= n; ++j) { dfs(i, j, 0); } } for (int i = 1; i <= n; ++i) { for (int j = 1; j <= n; ++j) { if (dp[i][j][0] == 0) { printf("B"); } else { printf("A"); } printf("\n"); } }}

转载地址:http://olewz.baihongyu.com/

你可能感兴趣的文章
npm报错Cannot find module ‘webpack‘ Require stack
查看>>
npm报错Failed at the node-sass@4.14.1 postinstall script
查看>>
npm报错fatal: Could not read from remote repository
查看>>
npm报错File to import not found or unreadable: @/assets/styles/global.scss.
查看>>
npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
查看>>
npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
查看>>
npm版本过高问题
查看>>
npm的“--force“和“--legacy-peer-deps“参数
查看>>
npm的安装和更新---npm工作笔记002
查看>>
npm的常用配置项---npm工作笔记004
查看>>
npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
查看>>
npm编译报错You may need an additional loader to handle the result of these loaders
查看>>
npm设置淘宝镜像、升级等
查看>>
npm设置源地址,npm官方地址
查看>>
npm设置镜像如淘宝:http://npm.taobao.org/
查看>>
npm配置安装最新淘宝镜像,旧镜像会errror
查看>>
NPM酷库052:sax,按流解析XML
查看>>
npm错误 gyp错误 vs版本不对 msvs_version不兼容
查看>>
npm错误Error: Cannot find module ‘postcss-loader‘
查看>>
npm,yarn,cnpm 的区别
查看>>