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

简述企业建设网站的必要性包就业的培训学校

简述企业建设网站的必要性,包就业的培训学校,初学者做网站的软件,安卓市场2021最新版下载AtCoder Beginner Contest 324 F Beautiful Path 需要一点思维的转化,一时竟然没想到。 题意 给定大小为 n n n 的有向图, m m m 条边,每条边有 b i , c i b_i,c_i bi​,ci​ 两个属性,需要找到一条从 1 ∼ n 1\sim n 1∼n…

AtCoder Beginner Contest 324

F Beautiful Path

需要一点思维的转化,一时竟然没想到。

题意

给定大小为 n n n 的有向图, m m m 条边,每条边有 b i , c i b_i,c_i bi,ci 两个属性,需要找到一条从 1 ∼ n 1\sim n 1n 的路径使得 w i = ( b 1 + b 2 + ⋯ + b k ) / ( c 1 + c 2 + ⋯ + c k ) w_i = (b_1+b_2+\dots+b_k) / (c_1+c_2+\dots+c_k) wi=(b1+b2++bk)/(c1+c2++ck) 最大。题目保证路径一定存在且无环。

思路

初看一时没思路,写了个到达 u u u 点时,以 w i w_i wi 的最大值为最优跑拓扑排序,这样显然是不对的,例如: 1 1 → 3 2 = 1 + 3 1 + 2 \frac 11\rightarrow \frac32 = \frac{1+3}{1+2} 1123=1+21+3 会比 1 1 → 1 1 = 1 + 1 1 + 1 \frac11\rightarrow \frac11=\frac{1+1}{1+1} 1111=1+11+1 更优,但是若是下一条边是 100 1 \frac{100}1 1100,两条路径更优的是 1 + 1 + 100 1 + 1 + 1 > 1 + 3 + 100 1 + 2 + 1 \frac{1+1+100}{1+1+1}>\frac{1+3+100}{1+2+1} 1+1+11+1+100>1+2+11+3+100.

这里需要转换一下思路:
求路径使得 max ⁡ ( b 1 + b 2 + b 3 ) / ( c 1 + c 2 + c 3 ) = w i \max(b_1 + b_2 + b_3) / (c_1 + c_2 + c_3) = w_i max(b1+b2+b3)/(c1+c2+c3)=wi
设答案为 r e s res res
( b 1 + b 2 + b 3 ) / ( c 1 + c 2 + c 3 ) = r e s (b_1 + b_2 + b_3) / (c_1 + c_2 + c_3) = res (b1+b2+b3)/(c1+c2+c3)=res
( b 1 + b 2 + b 3 ) = ( c 1 + c 2 + c 3 ) ∗ r e s (b_1 + b_2 + b_3) = (c_1 + c_2 + c_3) * res (b1+b2+b3)=(c1+c2+c3)res
b 1 − c 1 ∗ r e s + b 2 − c 2 ∗ r e s + b 3 − c 3 ∗ r e s = 0 b_1 - c_1 * res + b_2 - c_2 * res + b_3 - c_3 * res = 0 b1c1res+b2c2res+b3c3res=0
上式将 = = = 改成 ≥ \geq 显然也成立,于是就有了单调性,二分答案求解。

用拓扑排序时有个小坑点,从 1 1 1 出发可能有些节点到达不了,需要清除这些点的度。或者由于一定是小编号 → \rightarrow 大编号,可以直接循环求解。

代码

#include <bits/stdc++.h>
using namespace std;#define ll long long
#define double long doubleconst int N = 2e5 + 10;struct node{int v, b, c;
};
vector<node> g[N];int n, m, d[N], t[N];
double f[N];
bool topu(double x){queue<int> q;for(int i = 1; i <= n; i ++){t[i] = d[i];f[i] = -1e10;}q.push(1);f[1] = 0.0;while(!q.empty()){int u = q.front(); q.pop();for(auto [v, b, c] : g[u]){f[v] = max(f[v], f[u] + (double)b - (double)c * x);t[v] --;if(!t[v]) q.push(v);}}return f[n] >= 0;
}int vis[N];
void dfs(int u){if(vis[u]) return ;vis[u] = 1;for(auto [v, a, b] : g[u]) dfs(v);
}int main(){ios::sync_with_stdio(false);cin.tie(0); cout.tie(0);cin >> n >> m;for(int i = 1; i <= m; i ++){int u, v, b, c;cin >> u >> v >> b >> c;g[u].push_back({v, b, c});d[v] ++;}dfs(1);for(int i = 1; i <= n; i ++){ // 清除无法到达的节点的度if(vis[i]) continue ;for(auto [v, a, b] : g[i]) d[v] --;}double l = 0, r = 2e9;for(int i = 1; i <= 100; i ++){double mid = (l + r) / 2;if(topu(mid)) l = mid;else r = mid;}cout << fixed << setprecision(20) << l <<"\n";return 0;
}

G Generate Arrays(待补)

题意

思路

代码

http://www.tj-hxxt.cn/news/96041.html

相关文章:

  • 自己用自己电脑做网站空间b站推广2024mmm已更新
  • 附近装修公司联系方式seo快速排名多少钱
  • 网站可以用中国二字做抬头吗优化关键词推广
  • 做视频网站收费侵权吗以图搜图百度识图网页版
  • 电脑制作视频的软件有哪些视频seo优化教程
  • 网站分站怎么做申请网站域名要多少钱
  • 网站开发 注意事项seowhy教研室
  • 做钓鱼网站用哪种编程语言百度竞价托管费用
  • 机票网站制作深圳竞价托管
  • java做项目的网站深圳高端网站建设公司
  • 南宁网站制作企业网页百度
  • 0基础做网站用什么语言免费刷推广链接的软件
  • 定制网站开发公司国外产品推广平台
  • 购物网站首页设计网站推广的公司
  • 做网站购买模板怎么在百度上投放广告
  • 徐州网站app开发国产长尾关键词拘挖掘
  • 今日生猪价格表如何优化网络延迟
  • 建设网站明细报价表经典软文案例100例简短
  • 怎么做微信小说网站吗淘宝如何刷关键词增加权重
  • 什么网站没人做吸引人气的营销方案
  • 自己做网站要不要租服务器杭州百度推广优化排名
  • 卢松松的网站最佳搜索引擎磁力王
  • 舒城县建设局网站首页网站排名怎么做
  • 一级a做爰片免费网站 新闻公众号推广接单平台
  • 织梦cms官方网站湘潭关键词优化服务
  • 江苏 网站集约化建设方案seo网络营销推广公司
  • 图片存放网站做链接谷歌外贸平台叫什么
  • 服务器网站过多对排名百度客服电话人工服务热线
  • 唯品会 一家专做特卖的网站运营商大数据精准营销获客
  • 网站开发的实训内容今天重大新闻头条新闻