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

现在的网络怎么做网站app下载链接

现在的网络怎么做网站,app下载链接,销售网站建设考核指标,wordpress argo链接 这是一个比较经典的题目。容易想到求出两段路径重合的部分,然后贪心的放权值。那么跑三次最短路,枚举重合部分的端点即可。 正解没什么好说的。这题有趣的地方在于,如果数据比较弱,可能会把一些错误做法放过去。 一种错误…

链接

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

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

一种错误做法是:只求 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/717490/

相关文章:

  • 做素描的网站网站建设商家公司
  • 比较好的能组数学卷的网站做教案的在哪里做推广效果好
  • 手机建网站教程详情页设计
  • 网站备案到期企业做网站需要注意什么问题
  • 做效果图兼职的网站企业所得税税率2022
  • 网站建设方案书是啥江门发布
  • 比较好的设计欣赏网站网片加工厂家
  • 广州市 住房建设局网站什么是网店
  • 为企业做网站要向谁索要资料创建全国文明城市主题班会教案
  • 襄阳网站建设价格合肥网站关键词优化公司
  • 公司简介万能模板商丘搜索引擎优化
  • 区块链的网站怎么做c 网站建设
  • 做网站一定要备案吗网站制作自己做
  • 高防手表网站营销型网站建设个人总结怎么写
  • 免费简历在线制作网站做网站属于程序员吗
  • 北京通州网站设计公司行业网站建设申请报告
  • 公司网站怎么注册植树节ppt模板下载免费版
  • 软装潢.企业网站建设手机网站怎么布局
  • 湖南网站建设 系统网站建设推广哪家好
  • 福建企业网站开发在线写作网站
  • 网站推广方法主要有什么江苏中南建设集团网站是多少
  • 苗族网站建设一般pr做视频过程那个网站有
  • 微信公众号可以做几个微网站吗优化建议
  • 做爰试看的网站企业名称核准查询系统
  • 外销网站wordpress主题sleo
  • 页面效果华丽的网站wordpress用户注册免邮箱
  • 网站推广的定义app开发排名公司
  • 网站制作时间代码wordpress aliyun-oss
  • 汉川做网站文化建设包括哪些
  • wordpress 网站标题附近的广告设计公司在哪