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

淄博网站开发网泰快网站留言板html模板

淄博网站开发网泰快,网站留言板html模板,青岛 机械 中企动力提供网站建设,wordpress游客投稿链接 这是一个比较经典的题目。容易想到求出两段路径重合的部分,然后贪心的放权值。那么跑三次最短路,枚举重合部分的端点即可。 正解没什么好说的。这题有趣的地方在于,如果数据比较弱,可能会把一些错误做法放过去。 一种错误…

链接

这是一个比较经典的题目。容易想到求出两段路径重合的部分,然后贪心的放权值。那么跑三次最短路,枚举重合部分的端点即可。

正解没什么好说的。这题有趣的地方在于,如果数据比较弱,可能会把一些错误做法放过去。

一种错误做法是:只求 aaa 点和 ccc 点的单源最短路,然后在枚举端点的时候,认为端点一定在 a,ba,ba,b 或者 b,cb,cb,c 之间的最短路径上。这个结论是错误的,可以构造出这样的反例:

7 8 1 4 6
1 2 3 4 100 100 100 100
1 2
2 3
3 4
3 5
5 6
3 7
1 7
6 7

这里的答案显然是 131313,而错误做法可能会得到 111111111

这种构造的依据是最短路并不是唯一的。然而,即便最短路是唯一的,上面的做法依然不正确。不妨设 a,ba,ba,bb,cb,cb,c 两条最短路径共用了从点 mmm 到点 bbb 的路径,mmma,b,ca,b,ca,b,c 三个点的距离分别为 100,10,100100,10,100100,10,100,而在这两条路径外面有一个点 nnn,它到三个点的距离分别为 90,30,9090,30,9090,30,90,那么这个 nnn 点在上面的做法中是不会被遍历到的,但只需设计好权值,就可以使最优解经过这个点。

下面是正解的代码,最短路用 BFS 实现更好。

#include <bits/stdc++.h>
using namespace std;
#define pb push_back
using ll = long long;
const int maxn = 2e5 + 5;
const ll inf = 1e18;
vector<int> g[maxn];
void solve() {int n, m, A, B, C;cin >> n >> m >> A >> B >> C;vector<ll> w(m);for (auto& i : w) cin >> i;for (int i = 1, u, v; i <= m; ++i) {cin >> u >> v;g[u].pb(v);g[v].pb(u);}sort(w.begin(), w.end());vector<int> disA(n + 1, 0x3f3f3f3f);vector<int> disB(n + 1, 0x3f3f3f3f);vector<int> disC(n + 1, 0x3f3f3f3f);vector<int> p(n + 1);function<void(int, vector<int>&)> dijkstra = [&](int s, vector<int>& d) {vector<int> vis(n + 1, 0);struct node {int id, dis;bool operator < (const node& rhs) const {return (dis == rhs.dis ? id > rhs.id : dis > rhs.dis);}};priority_queue<node> q;d[s] = 0;q.push({ s, 0 });while (!q.empty()) {auto [cur, cost] = q.top();q.pop();if (vis[cur]) continue;vis[cur] = 1;d[cur] = cost;for (auto to : g[cur]) {if (vis[to]) continue;if (d[to] > d[cur] + 1) {d[to] = d[cur] + 1;q.push({ to, d[to] });p[to] = cur;}}}};vector<ll> pre(m + 1, 0);for (int i = 1; i <= m; ++i) {pre[i] = pre[i - 1] + w[i - 1];}dijkstra(A, disA);dijkstra(B, disB);dijkstra(C, disC);ll ans = inf;for (int i = 1; i <= n; ++i) {int da = disA[i], db = disB[i], dc = disC[i];if (da + db + dc > m) continue;ans = min(ans, pre[db] + pre[da + db + dc]);}cout << ans << endl;for (int i = 1; i <= n; ++i) {g[i].clear();}
}
int main() {ios::sync_with_stdio(false);cin.tie(nullptr);int T = 1;cin >> T;while (T--) {solve();}return 0;
}
http://www.yayakq.cn/news/317532/

相关文章:

  • 定制开发一个网站多少钱岳塘区建设路街道网站
  • 杭州建网站的公司办公室装修风格效果图
  • 网站建设林晓东网站怎么做镜像
  • 虚拟钱包对接网站开发视频教程cc后缀网站
  • 网站名称和备案扬州市建设局网站
  • 南通宏仁建设工程有限公司招聘网站公司介绍ppt范例
  • 佛山网站建设哪家便宜双语网站建设公司
  • 中山建网站报价wordpress 动态链接
  • c2c网站设计设计师可以做兼职的网站
  • 城阳做网站找哪家好关于网站建设的意见
  • 南通网站定制企业本网站立足于海外服务器
  • 网站建设年度计划网站没备案怎么做加速
  • 手机移动端网站建设深圳市科技网站开发
  • 大连网站设计布局中山网站设计与建设
  • 自己怎么做装修网站自己做网站如何挣钱
  • 中企动力 做网站 怎么样专业的seo排名优化
  • 搜索引擎主题网站模板万网做网站顺序
  • 做网站需要注意什么问题百度网站官网
  • 网站快速排名网文订阅做多的网站
  • 郑州做网站经开区阿里巴巴的网站应该怎么做
  • 网站开发设计方案书网络运维工程师面试题
  • 怎么能自己创建网站做网站app的工资高吗
  • wordpress 副标题调用福州网站seo
  • 网站建设属于莘县网站定制
  • 网站建设选择服务器快速网站开发课程
  • 黄金网站app下载免费上海松江区网站建设
  • 东莞电子产品网站建设建设银行网站查余额查询
  • 精品在线开发网站建设环境设计专业介绍
  • 宁波网站建设网站开发可以在什么网站做二建题目
  • 泸州市住房和城乡建设厅官方网站国家建筑工程信息平台