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

南通做网站优化谷歌排名推广公司

南通做网站优化,谷歌排名推广公司,国家卫生健康委卫生健康监督中心,百度竞价培训班不难看出,这是一道在图上 D P DP DP的问题。设 f i f_i fi​表示从 i i i出发,能够不停的游走下去,所需要的最少的初始资产。可以写出粗略的转移: f u min ⁡ ( f u , max ⁡ ( f v − p i , r i ) ) f_u\min(f_u,\max(f_v-p_i,r…

不难看出,这是一道在图上 D P DP DP的问题。设 f i f_i fi表示从 i i i出发,能够不停的游走下去,所需要的最少的初始资产。可以写出粗略的转移: f u = min ⁡ ( f u , max ⁡ ( f v − p i , r i ) ) f_u=\min(f_u,\max(f_v-p_i,r_i)) fu=min(fu,max(fvpi,ri))

一个粗略的想法是,我们找出所有的环,然后跑 spfa \text{spfa} spfa。但是找环需要枚举环上的一个点,难以优化。

我们能想到的比较高效的找环方式是拓扑排序(在这道题目中,拓扑排序的主要用途是帮助我们删掉出度为 0 0 0的点,从而找到所有的环)。因此,考虑删掉所有出度为 0 0 0的点,此时每个点都至少在一个环中,因此 f u f_u fu的初值是 r m a x r_{max} rmax。(事实上,我们甚至可以通过拓扑排序找到包含节点 u u u的所有环中 r m a x r_{max} rmax的最小值,这一点后面会提到)。

考虑如何求出 f u f_u fu。我们用一个队列维护已经确定的所有的 f u f_u fu,每次在图中找到 r i r_i ri最大的边 ( u , v , r , p ) (u,v,r,p) (u,v,r,p),如果 f v f_v fv的值已经确定了,那么用 f v f_v fv去更新 f u f_u fu;否则,我们发现 r r r恰好是环上边的最大值(因为 v v v还没有入队),可以直接用 r r r去更新 f u f_u fu。然后我们将这条最大的边从图中删去,将出度为 0 0 0的点加入队列即可。注意每次操作完要将队列清空(保证每个点至少在一个环中)。

仔细思考这个过程,事实上和通过拓扑排序找到所有 f u f_u fu的初值(包含 u u u的所有环中 r m a x r_{max} rmax的最小值),然后跑 spfa \text{spfa} spfa等价。(当然 spfa \text{spfa} spfa更慢)

复杂度 O ( m log ⁡ m ) O(m\log m) O(mlogm)。瓶颈在于排序。

考场上居然没想到用拓扑排序找环。。。可能还是因为惯性思维,因为不是 D A G DAG DAG所以没想到拓扑排序吧。

#include<bits/stdc++.h>
#define ll long long
#define pb push_back
#define fi first
#define se second
#define inf 0x3f3f3f3f3f3f3f3f
using namespace std;
const int N=2e5+5;
int n,m,du[N],vs[N];
struct node{int u,v,r,p;bool operator <(const node &a)const{return r>a.r;}
}e[N];
ll f[N];
queue<int>Q;
vector<int>G[N];
void chmin(ll &x,ll y){x=min(x,y);
}
int main(){ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);cin>>n>>m;for(int i=1;i<=m;i++){cin>>e[i].u>>e[i].v>>e[i].r>>e[i].p;}sort(e+1,e+1+m);for(int i=1;i<=m;i++){G[e[i].v].pb(i),du[e[i].u]++;}memset(f,0x3f,sizeof f);for(int i=1;i<=n;i++)if(du[i]==0)Q.push(i);for(int i=1;i<=m;i++){while(Q.size()){int u=Q.front();Q.pop();for(auto id:G[u]){if(vs[id])continue;int v=e[id].u;if(f[u]!=inf)chmin(f[v],max(f[u]-e[id].p,1ll*e[id].r));vs[id]=1;if(--du[v]==0)Q.push(v);}}if(!vs[i]){vs[i]=1;chmin(f[e[i].u],e[i].r);if(--du[e[i].u]==0)Q.push(e[i].u);}}for(int i=1;i<=n;i++)cout<<(f[i]==inf?-1:f[i])<<" ";
}
http://www.dt0577.cn/news/18535.html

相关文章:

  • 有域名如何自己制作网站百度云服务器官网
  • 做php网站需要什么软件2345网址大全浏览器
  • 郴州网站建设培训代运营网店公司
  • 凡科网做网站收费吗运营培训
  • 做盗版网站 国外服务器百度应用商店官网
  • 微信分享接口网站开发关键词三年级
  • 平面设计如何接单seo是什么意思seo是什么职位
  • WordPress怎么修改网站登陆地址seo教程自学网
  • 效果图外包seo是什么专业
  • 专用车网站建设哪家好seo做什么网站赚钱
  • 建设银行手机银行网站用户名seo站长工具
  • 企业如何建官方网站如何线上推广引流
  • 昆明app制作湖州网站seo
  • wordpress编辑作者投稿者英文seo怎么做排名
  • 微网站的链接怎么做的站长工具忘忧草社区
  • 南山模板网站建设公司网络营销的用户创造价值
  • 做网站大概多少进入百度一下官网
  • 网站的策划方案上海十大公关公司排名
  • 网易门户网站建设nba最新交易动态
  • 什么网站都有漏洞肇庆seo优化
  • 郴州网站建设百度关键词优化系统
  • 电子商务网站建设费用百度推广效果不好怎么办
  • 天河网站建设服务南宁网络推广服务商
  • 新建门户网站的建设自查南宁网络推广外包
  • 做款app多少钱seo是什么缩写
  • 购物网站功能设计今天特大新闻最新消息
  • 二手车网站开发背景百度云网站入口
  • 顺德装修网站建设推广赚钱软件
  • iis发布网站页面出问题win优化大师有免费版吗
  • 用dw做网站流程网站建设方案开发