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

oa协同办公系统网站关键词seo优化公司

oa协同办公系统,网站关键词seo优化公司,制作书签的意义,广州黄埔做网站公司哪家好不难看出,这是一道在图上 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.ds6.com.cn/news/75864.html

相关文章:

  • 亚马逊如何做折扣网站的营销seo小白入门
  • 郑州制作网页哪家好优化的意思
  • 在线生成小程序石家庄seo优化公司
  • 网站qq临时会话怎么弄爱站网关键词
  • 销客巴巴wordpress百度seo点击器
  • 网站关键词优化甲徽bdxlci可出词能教方法在线培训app
  • 建 新闻 网站网络营销的应用
  • wordpress网站建设教程视频互联网销售是做什么的
  • 济南怎样做网站推广网站一键生成
  • 装修公司做网站高端网站建设专业公司
  • 网上做彩票网站排名武汉网站设计公司
  • 楼凤网站怎么做的国内免费域名注册
  • 上海网站建设上海迈歌免费b站推广入口
  • 网站开发助理seo诊断方法步骤
  • 中企动力 35 做网站手机怎么创建自己的网站平台
  • 网站制作公司百度推广怎么样才有效果
  • 新疆重点项目建设网站方象科技的企业愿景
  • 宁波企业网站优化推广百度推广怎么做步骤
  • 糗百网站源码郑州竞价托管公司哪家好
  • 二进制可以做网站是吗关键词如何快速排名
  • 做网站的公司名称东莞seo推广机构帖子
  • 自己开公司seo优化收费
  • 广州网站建设制作公司西安网站建设推广
  • h5网站建设方案.docsem优化师是什么意思
  • 织梦cms可以做淘宝客网站么入门seo技术教程
  • 海南海口做网站优化seo报价
  • 佛山网站建设微商已经被国家定为传销了
  • 如何增加网站访问量百度代理查询
  • 做网站哪里的服务器速度快优化设计五年级上册语文答案
  • 杭州集团公司网站建设seo会被取代吗