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

荆州北京网站建设网站seo优化服务

荆州北京网站建设,网站seo优化服务,h5手机制作软件app有哪些,一番赏公众号开发https://atcoder.jp/contests/arc165/tasks/arc165_f 首先可以建图&#xff0c;然后变成求字典序最小的的拓扑排序 然后发现这样复杂度会炸&#xff0c;观察连边的条件是什么&#xff1a; l i < l j l_i<l_j li​<lj​ r i < r j r_i<r_j ri​<rj​ 这是个…

https://atcoder.jp/contests/arc165/tasks/arc165_f

首先可以建图,然后变成求字典序最小的的拓扑排序

然后发现这样复杂度会炸,观察连边的条件是什么:

  • l i < l j l_i<l_j li<lj
  • r i < r j r_i<r_j ri<rj

这是个二维偏序问题,我们考虑用分治来解决

我们按 l l l 排序,本区间内再按 r r r 排序:

在这里插入图片描述

复杂度 O ( n log ⁡ 2 n ) O(n\log^2n) O(nlog2n)

#include<bits/stdc++.h>
using namespace std;
#ifdef LOCAL#define debug(...) fprintf(stdout, ##__VA_ARGS__)
#else#define debug(...) void(0)
#endif
//#define int long long
inline int read(){int x=0,f=1;char ch=getchar(); while(ch<'0'||
ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){
x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}return x*f;}
#define Z(x) (x)*(x)
#define pb push_back
#define fi first
#define se second
//srand(time(0));
#define N 5000010
//#define M
//#define mo
struct node {int l, r, id, op; 
}a[N];
int n, m, i, j, k, T;
struct cmp {bool operator () (int x, int y) const {if(x<=n && y>n) return 1; if(y<=n && x>n) return 0; if(x<=n && y<=n) return x>y; if(x>n && y>n) return x>y; }
};
priority_queue<int, vector<int>, cmp >q; 
int c[N], b[N], tot; 
vector<int>G[N]; void cun(int x, int y) {
//	debug("%d -> %d\n", x, y); G[x].pb(y); ++c[y]; 
}void solve(int l, int r) {int i; if(l==r) return ; int mid=(l+r)>>1; solve(l, mid); solve(mid+1, r); for(i=l; i<=mid; ++i) a[i].op=0; for(i=mid+1; i<=r; ++i) a[i].op=1; sort(a+l, a+r+1, [&] (node x, node y) { return x.r<y.r; }); for(i=l; i<=r; ++i) b[i]=++tot; for(i=l; i<=r-1; ++i) cun(b[i], b[i]+1); for(i=l; i<=r; ++i) if(a[i].op==0) cun(a[i].id, b[i]); else cun(b[i], a[i].id); 
}signed main()
{#ifdef LOCALfreopen("in.txt", "r", stdin);freopen("out.txt", "w", stdout);#endif
//	T=read();
//	while(T--) {
//
//	}n=read(); tot=n; for(i=1; i<=n; ++i) a[i].id=i; for(i=1; i<=2*n; ++i) {k=read(); if(!a[k].l) a[k].l=i; else a[k].r=i; }sort(a+1, a+n+1, [] (node x, node y) { return x.l<y.l; }); solve(1, n); for(i=1; i<=tot; ++i) if(!c[i]) q.push(i); while(!q.empty()) {auto u=q.top(); q.pop(); 
//		debug("# %d\n",  u); if(u<=n) printf("%d %d ", u, u); for(auto v : G[u]) if(--c[v]==0) q.push(v); }return 0;
}
http://www.mmbaike.com/news/111305.html

相关文章:

  • 网站推广南京公司电商运营多少钱一个月
  • 北京燕华工程建设有限公司网站黑马培训机构
  • 湖南做旅游网站能打开任何网站浏览器
  • 网站开发支持二次开发怎么做线上推广
  • 公司规模介绍范文电子商务seo名词解释
  • 石狮做网站电脑优化工具
  • 国外用什么做网站买友情链接
  • 昆明做网站做的好的公司有哪些西安seo网络优化公司
  • 比特币做空网站银川seo优化
  • 视频网站开发难点温州seo网站建设
  • 在本地搭建多个网站百度网站app
  • 外贸网站域名能用cn做后缀吗需要推广的app在哪里找
  • 视频网站怎么做统计表企业网站模板html
  • 前端做用vue做后台多还是做网站多建筑设计网站
  • 网站建设要程序员吗网站建设与管理主要学什么
  • 学校网站 asp今日的新闻
  • 阳江做网站多少钱seo百度快速排名
  • 网站建设战略伙伴如何网站推广
  • 餐饮网站做的比较好的是哪个昆明网络推广方式有哪些
  • 个人可否建立网站百度seo排名优化软件化
  • 有没有做ppt很厉害的网站百度指数查询移动版
  • 梁露 网站建设与实践宣传渠道和宣传方式有哪些
  • 卫生监督 网站建设方案如何注册域名及网站
  • 河南网络科技网站建设今日关注
  • wordpress建视频网站可以吗南宁seo团队哪家好
  • 淘宝网站建设基本流程seo整站优化哪家好
  • 网站建设 合优网络湖南靠谱seo优化公司
  • 绵阳城乡住房建设厅网站女教师遭网课入侵视频大全播放
  • 广州网站营销优化开发宁波seo教学
  • 移动端网站如何做开放式配凤凰网全国疫情实时动态