MX-S

太简单了,没啥难度。\yiw

$ 1, 3, 5, 7, 9 $ 的二叉搜索树棵数是卡特兰数。

P6029

题意

给定一张有 $ n $ 个点,$ m $ 条边的图。可以任意交换途中两条边的权值不超过 $ K $ 次,问最后 $ 1 $ 到 $ n $ 的最短路径长度。

$ 1 \le n \le 50 \(,\) 1 \le m \le 150 \(,\) 1 \le K \le 20 $

Solution

这题是某次初赛模拟的时候放上来,似乎比较水,就写了一下。

不难想到一种贪心:直接将所有的最小边能换到路径上就换。

但是这样不一定是最优的,所以考虑枚举最后在路径上的边为所有边中前 $ i $ 小的。

并且用 Dp 在 Dijkstra 的同时计算。

设 $ f_{u, j, k} $ 表示从 $ 1 $ 到 $ u $ 的路径上有 $ j $ 条为前 $ i $ 小的边,且使用了 $ k $ 次交换魔法的最短路径长度。

设当前点为 $ u $,下一个节点为 $ v $,则转移方程如下:

  • 当 $ k + 1 \le K $ 时,$ f_{u, j, k} $ 可以更新 $ f_{v, j, k + 1} $。
  • 当遍历到的 $ (u, v) $ 这条边属于前 $ i $ 条边时,则将这条边边权设为 $ 0 $,并且设 $ j1 = j + 1 $,否则为 $ j $(因为前 $ i $ 条边在最后统一计算前缀和)。此时当 $ j1 \le m $ 时,则可以用 $ f_{u, j, k} + w $ 更新 $ f_{v, j1, k} $。

最后统计答案时,就枚举前 $ i $ 条最小边和 $ j, k $,再处理一个 $ sum $ 表示前 $ i $ 小的边权前缀和,然后在所有 $ f_{n, j, k} + sum $ 中取最小值即可,但是要注意的是枚举条件 $ j + k \le i $。

//Asahina Mafuyu
#include <bits/stdc++.h> using namespace std; const int N = 55, M = 155, K = 25; struct two_plus_four
{
int id, v, w;
};
struct three_plus_three
{
int u, j, k, f;
bool operator < (const three_plus_three & W) const
{
return f > W.f;
}
}; int n, m, k;
int w[M], id[M], mp[M];
int f[N][M][K];
bool st[N][M][K];
vector<two_plus_four> gph[N]; bool cmp(int a, int b)
{
return w[a] < w[b];
} void dijkstra(int limit)
{
memset(f, 0x3f, sizeof f);
memset(st, 0, sizeof st);
priority_queue<three_plus_three> q;
q.push({1, 0, 0, 0});
f[1][0][0] = 0;
while (q.size())
{
auto t = q.top(); q.pop();
int u = t.u, j = t.j, K = t.k;
if (st[u][j][K]) continue;
st[u][j][K] = 1; for (auto x : gph[u])
{
int v = x.v, w_ = x.w, id_ = x.id, j1 = j;
if (K < k && f[v][j][K + 1] > f[u][j][K])
{
f[v][j][K + 1] = f[u][j][K];
q.push({v, j, K + 1, f[v][j][K + 1]});
}
if (mp[id_] <= limit) j1 ++ , w_ = 0;
if (j1 <= m && f[v][j1][K] > f[u][j][K] + w_)
{
f[v][j1][K] = f[u][j][K] + w_;
q.push({v, j1, K, f[v][j1][K]});
}
}
}
} int main()
{
cin >> n >> m >> k;
for (int i = 1; i <= m; i ++ )
{
int a, b, c;
cin >> a >> b >> c;
gph[a].push_back({i, b, c}), gph[b].push_back({i, a, c});
id[i] = i, w[i] = c;
} sort(id + 1, id + m + 1, cmp);
sort(w + 1, w + m + 1);
for (int i = 1; i <= m; i ++ ) mp[id[i]] = i;
int s = 0, res = 0x3f3f3f3f;
for (int i = 0; i <= m; i ++ )
{
s += w[i];
dijkstra(i);
for (int j = 0; j <= i; j ++ )
for (int K = 0; K <= k && j + K <= i; K ++ )
res = min(res, f[n][j][K] + s);
} cout << res << '\n'; return 0;
}

2024.09.18初赛模拟MX-S/P6029记录的更多相关文章

  1. "2016-10-06T12:09:18.303+0800"

    Java public static void main(String[] args) throws ParseException { SimpleDateFormat sdf = new Simpl ...

  2. [转]如何解决:Android中 Error generating final archive: Debug Certificate expired on 10/09/18 16:30 的错误

    本文转自:http://www.cnblogs.com/yyangblog/archive/2011/01/07/1929657.html 问题概述: 在导入一个app后提示如下错误: “Error ...

  3. 2018.08.18 NOIP模拟 game(数位dp)

    Game 题目背景 SOURCE:NOIP2015-SHY4 题目描述 Alice 和 Bob 正在玩一个游戏,两个人从 1 轮流开始报数,如果遇到 7 的倍数或者遇到的这个数的十进制表示中含 7 , ...

  4. 软件工程项目组Z.XML会议记录 2013/09/18

    软件工程项目组Z.XML会议记录 [例会时间]2013年9月18日周三21:00-23:00 [例会形式]小组讨论 [例会地点]三号公寓楼会客厅 [例会主持]李孟 [会议记录]毛宇 会议整体流程 一. ...

  5. 7.18 NOI模拟赛 树论 线段树 树链剖分 树的直径的中心 SG函数 换根

    LINK:树论 不愧是我认识的出题人 出的题就是牛掰 == 他好像不认识我 考试的时候 只会写42 还有两个subtask写挂了 拿了37 确实两个subtask合起来只有5分的好成绩 父亲能转移到自 ...

  6. 7.18 NOI模拟赛 因懒无名 线段树分治 线段树维护直径

    LINK:因懒无名 20分显然有\(n\cdot q\)的暴力. 还有20分 每次只询问一种颜色的直径不过带修改. 容易想到利用线段树维护直径就可以解决了. 当然也可以进行线段树分治 每种颜色存一下直 ...

  7. 修改MS SQL忽略大小写 分类: SQL Server 数据库 2015-06-19 09:18 34人阅读 评论(0) 收藏

    第一步:数据库->属性->选项->限制访问:SINGLE_USER 第二步:ALTER DATABASE [数据库名称] collate Chinese_PRC_CI_AI 第三步: ...

  8. 10.18 noip模拟试题

    分火腿 (hdogs.pas/.c/.cpp) 时间限制:1s:内存限制 64MB 题目描述: 小月言要过四岁生日了,她的妈妈为她准备了n根火腿,她想将这些火腿均分给m位小朋友,所以她可能需要切火腿. ...

  9. 【.NetRemoting-3】2015.09.18

    [Remoting程序的基本实现] [一]服务程序集 [1]服务对象必须要求继承[MBR,MarshalByRefObject] [二]服务端应用程序 [1]注册通道 [两种类型的通道] [A]发送请 ...

  10. 虚拟机时间同步14 Aug 04:09:18 ntpdate[2941]: no server suitable for synchronization found

    因为虚拟机经常挂起,所以需要时间同步 [root@slave1 /root]$ cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime cp: over ...

随机推荐

  1. 2023HACSP-J补测

    都快忘了自己还打过这个比赛了,所以来补一下. 完整题目在这里查看. Day0 来到郑州,寻找考场.幸好提前来了,因为考场大门就 5m 宽(HA用不用这么穷啊喂,来JZYZ不好么),开车转了 20min ...

  2. 学习笔记--Java中this关键字

    Java中this关键字 关于Java语言中的this关键字 this 是一个关键字,翻译为:这个 this 是一个引用,一个变量,this变量中保存的内存地址指向自身 每一个对象都有自己的this, ...

  3. ScaleDet:AWS 基于标签相似性提出可扩展的多数据集目标检测器 | CVPR 2023

    论文提出了一种可扩展的多数据集目标检测器(ScaleDet),可通过增加训练数据集来扩大其跨数据集的泛化能力.与现有的主要依靠手动重新标记或复杂的优化来统一跨数据集标签的多数据集学习器不同,论文引入简 ...

  4. RBAC权限模型概述

    RBAC即role-based access control,基于角色的访问控制 通过角色来管理用户对系统资源的访问权限.RBAC是一种权限管理模型,核心思想是分离用户与具体权限,通过角色作为中介来实 ...

  5. vue中的<script setup>与<script>

    <script setup>是在vue3.2之后新增的语法糖,简化了API的写法 1.声明的变量无需return,可以直接在模板中使用,实现了顶层的绑定 2.引入组件会自动注册,无需再使用 ...

  6. 概括下为什么要用vue开发

    很多老程序员,习惯了使用原生html和js来开发前端页面,对于很多没用过vue的程序员来说,觉得没有必要. 下面,我来概括下vue的一些好处: 1.控件自动跟数据绑定,提交表单到后台的时候,可以直接使 ...

  7. JAVA并发编程理论基础

    注:本文章是对极客时间<java并发编程实战>学习归纳总结,更多知识点可到原文 java并发编程实战 进行学习.如果侵权,联系删除: 一.并发编程的BUG的源头 1.1 缓存导致的可见性问 ...

  8. 【Layui】13 轮播 Carousel

    文档地址: https://www.layui.com/demo/carousel.html 基础轮播: <style> /* 为了区分效果 */ div[carousel-item]&g ...

  9. OpenCV计算机视觉学习(16)——仿射变换学习笔记

    如果需要其他图像处理的文章及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractic ...

  10. 工作站CPU超频,通过测试软件的压力测试就OK了吗?终极测试还是要看具体的应用场景

    最近想起超频试试自己年初入手的工作站,也是纯玩,超超频,看看是什么个体验,不过这个过程中还真有所学习. 由于电脑的主板,电源,散热等配的都比较高端,所以上来直接超频5.2G,电压选择为自动,不过再整个 ...