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

做网站服务器怎么用温州网站设计制作

做网站服务器怎么用,温州网站设计制作,wordpress网站重新安装插件,望野赏析[蓝桥杯 2022 国 B] 出差 题目描述 A \mathrm{A} A 国有 N N N 个城市#xff0c;编号为 1 … N 1 \ldots N 1…N 小明是编号为 1 1 1 的城市中一家公司的员工#xff0c;今天突然接到了上级通知需要去编号为 N N N 的城市出差。 由于疫情原因#xff0c;很多直达的交…[蓝桥杯 2022 国 B] 出差 题目描述 A \mathrm{A} A 国有 N N N 个城市编号为 1 … N 1 \ldots N 1…N 小明是编号为 1 1 1 的城市中一家公司的员工今天突然接到了上级通知需要去编号为 N N N 的城市出差。 由于疫情原因很多直达的交通方式暂时关闭小明无法乘坐飞机直接从城市 1 1 1 到达城市 N N N需要通过其他城市进行陆路交通中转。小明通过交通信息网查询到了 M M M 条城市之间仍然还开通的路线信息以及每一条路线需要花费的时间。 同样由于疫情原因小明到达一个城市后需要隔离观察一段时间才能离开该城市前往其他城市。通过网络小明也查询到了各个城市的隔离信息。由于小明之前在城市 1 1 1因此可以直接离开城市 1 1 1不需要隔离 由于上级要求小明希望能够尽快赶到城市 N \mathrm{N} N, 因此他求助于你希望你能帮他规划一条路线能够在最短时间内到达城市 N N N 。 输入格式 第 1 1 1 行两个正整数 N , M N, M N,M 表示 A 国的城市数量, M M M 表示末关闭的路线数量。 第 2 2 2 行: N N N 个正整数第 i i i 个整数 C i C_{i} Ci​ 表示到达编号为 i \mathrm{i} i 的城市后需要隔离的时间。 第 3 … M 2 3 \ldots M2 3…M2 行: 每行 3 3 3 个正整数, u , v , c u, v, c u,v,c, 表示有一条城市 u u u 到城市 v v v 的双向路线仍然开通着通过该路线的时间为 c c c。 输出格式 第 1 1 1 行 1 1 1 个正整数表示小明从城市 1 1 1 出发到达城市 N N N 的最短时间。到达城市 N N N不需要计算城市 N N N 的隔离时间 样例 #1 样例输入 #1 4 4 5 7 3 4 1 2 4 1 3 5 2 4 3 3 4 5样例输出 #1 13提示 【样例说明】 【评测用例规模与约定】 对于 100 % 100 \% 100% 的数据, 1 ≤ N ≤ 1000 , 1 ≤ M ≤ 10000 , 1 ≤ C i ≤ 200 , 1 ≤ u , v ≤ 1 \leq N \leq 1000,1 \leq M \leq 10000,1 \leq C_{i} \leq 200,1 \leq u, v \leq 1≤N≤1000,1≤M≤10000,1≤Ci​≤200,1≤u,v≤ N , 1 ≤ c ≤ 1000 N, 1 \leq c \leq 1000 N,1≤c≤1000 蓝桥杯 2022 国赛 B 组 E 题。 思路 首先从输入中读取城市数量 n 和开放的路线数量 m。然后读取每个城市的隔离时间存储在数组 c 中。接着读取 m 条边的信息每条边包含起始城市 u目标城市 v以及通过该路线需要的时间 w。对于每条边都将其添加到链式前向星中同时将该城市的隔离时间加到边的权重上。这样做的目的是在计算从城市 u 到城市 v 的时间时同时考虑了在城市 v 的隔离时间。 通过 Dijkstra 算法来找到从城市 1 到城市 n 的最短路径。使用 vis.reset() 初始化所有节点为未访问状态。然后对于每个节点如果节点是源点城市 1则其到自己的最短距离 dist[i] 为 0并将其加入优先队列 hmin 中。否则将其最短距离设置为无穷大并将其前驱节点 prior[i] 设置为 -1表示还没有找到到达它的最短路径。 然后进入主循环当优先队列不为空时取出队列顶部的节点 t其中 t.v 是节点编号t.d 是从源点到该节点的当前最短距离。如果该节点已经被访问过则跳过。否则将其标记为已访问。然后遍历从节点 u 出发的所有边如果通过当前边到达节点 v 的距离 du edge[i].w 小于 v 的当前最短距离 dist[v]则更新 dist[v]并将 v 加入优先队列。 这个过程会持续直到优先队列为空或者找到目标节点 n。注意dist[v] 中的值是从源点到达 v 并在 v 进行隔离的总时间所以在最后的结果中需要减去城市 n 的隔离时间。 注意 到达一个城市后需要隔离观察一段时间才能离开该城市前往其他城市将终点城市的隔离时间加到边的权重上即可。到达城市 n 后不需要隔离所以在最后的结果中需要减去城市 n 的隔离时间。 AC代码 #include algorithm #include bitset #include cmath #include cstring #include iostream #include queue #define AUTHOR HEX9CF using namespace std; using ll long long;const int N 1e6 7; const int INF 0x3f3f3f3f; const ll MOD 1e9 7;struct Edge {int w, to, next; } edge[N]; int head[N]; int cnt 0;struct Node {int v, d;bool operator(const Node b) const { return d b.d; } };int n, m; int c[N];// 最短路径长度 int dist[N]; // 前驱节点 int prior[N]; bitsetN vis; priority_queueNode hmin;void add(int u, int v, int w) {edge[cnt] {w, v, head[u]};head[u] cnt; }void dijkstra() {vis.reset();for (int i 1; i n; i) {if (i 1) {dist[i] 0;hmin.push({i, 0});} else {dist[i] INF;prior[i] -1;}}while (hmin.size()) {auto t hmin.top();hmin.pop();int u t.v;int du t.d;if (vis[u]) {continue;}vis[u] 1;for (int i head[u]; ~i; i edge[i].next) {int v edge[i].to;if (dist[v] (du edge[i].w)) {dist[v] du edge[i].w;prior[v] u;hmin.push({v, dist[v]});}}} }int main() {ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);memset(head, -1, sizeof(head));cin n m;for (int i 1; i n; i) {cin c[i];}for (int i 1; i m; i) {int u, v, w;cin u v w;// 到达一个城市后需要隔离观察一段时间才能离开该城市前往其他城市add(u, v, w c[v]);add(v, u, w c[u]);}dijkstra();// 到达n城后不需要隔离cout dist[n] - c[n] \n;return 0; }
http://www.pierceye.com/news/394898/

相关文章:

  • 哪个网站有帮忙做公开课课件怎么查那些人输入做网站
  • 怎么做qq钓鱼网站吗有哪些站内推广的方式
  • wap手机网站建设校园论坛网站怎么做
  • 北京专业网站的建设滨州做网站的
  • 网站点击排名wordpress 联系我们
  • 上街免费网站建设seo外包公司优化
  • 营销型网站的三大特点安徽网站设计方案
  • 优化网站推广教程排名做微信公众号页面的网站
  • 龙岗网站设计效果台州百度关键词排名
  • 政务类网站建设ps做全屏网站画布要多大
  • 百度广告搜索推广seo如何快速排名百度首页
  • 网站调用微信数据网站开发语言windows
  • 网站建设的公青岛专业网站制作设计
  • 东莞营销型网站学动漫设计有前途吗
  • 资讯网站wordpress实例配置
  • 营销网站建设哪里便宜最新房地产新闻
  • 有自己的网站怎么做淘宝客wordpress不自动安装
  • 我自己做网站wcf网站开发
  • 做一个好的网站需要什么店铺设计合同
  • 做网站公司郑州设计师能做网站前端吗
  • 建设工程交易中心网站中国监察报电子版
  • 网站正在建设中 倒计时软文写作范例大全
  • 左中右三栏布局网站建设网站建设微金手指下拉15
  • 做网站公司怎么找数字营销招聘
  • 做网站域名和空间费如何创建一个新网站
  • 前程无忧网广州网站建设类岗位wordpress建站教程视频
  • 徐州建设公司网站最吉祥的公司名字大全
  • wordpress网站前端优化怎么做网站导航地图
  • 成都市武侯区建设局门户网站自助快速建站
  • 专业视频网站开发公司兰州装修公司报价明细表