Codeforces 题面传送门 & 洛谷题面传送门

中规中矩的构造题一道。

首先考虑将两张图都向一个中间状态转化。方便起见我们取所有点都连向 \(1\) 号点的情形作为中间状态。

考虑怎样从初始状态向我们这个中间状态转化。显然我们要将所有不与 \(1\) 相连的对角线都变得与 \(1\) 相连对吧,那我们就考虑从 \(2\) 开始枚举每一个点 \(x\) 以及一个与 \(x\) 相连的边 \((x,y)(x<y)\),满足 \(y\) 与 \(1\) 有边,如果 \(|x-y|>2\) 说明这条对角线不符合要求,我们就找出 \(x,y\) 所在的四边形,显然一个端点是 \(1\),另一个端点枚举一下即可找出,假设为 \(z\),那么我们就操作 \(1,x,y,z\) 构造的四边形,将 \((x,y)\) 变成 \((1,z)\)。如果我们找不到这样的 \(y\) 说明不存在与 \(x\) 相连的不合法的边,我们就继续进入到下一个 \(x\) 即可。容易发现每次操作会恰好使一个不合法的边变得合法,而总边数最多只有 \(n-1\),因此总操作次数的上限为 \(2n-2\)。

时间复杂度 \(\mathcal O(n^2)\)。

事实上本题如果用 bitset 优化数据范围可以出到 \(5\times 10^4\),具体解法就是对每个点开一个 bitset 存储与其相连的点,然后用 bitset 的取并和 _Find_first() 函数找出符合要求的 \(y\),再用 bitset 的取并找出 \(x,y\) 对应的 \(z\)。

const int MAXN=1000;
int n;
struct solver{
vector<pii> op;int tp,a[MAXN+5][MAXN+5];
void read(){int u,v;scanf("%d%d",&u,&v);a[u][v]=a[v][u]=1;}
void work(){
for(int i=1;i<=n;i++) a[i%n+1][i]=a[i][i%n+1]=1;
for(int i=2;i<n;i++) if(a[1][i]){
while(1){
int ps=n;
for(int j=i+1;j<=n;j++) if(a[1][j]){ps=j;break;}
if(ps==i+1) break;
for(int j=i+1;j<ps;j++) if(a[ps][j]&&a[i][j]){
a[j][1]=a[1][j]=1;a[i][ps]=a[ps][i]=0;
(tp)?op.pb(mp(i,ps)):op.pb(mp(1,j));break;
}
}
}
}
} s1,s2;
int main(){
scanf("%d",&n);
for(int i=1;i<=n-3;i++) s1.read();
for(int i=1;i<=n-3;i++) s2.read();
s1.tp=1;s1.work();s2.work();printf("%d\n",s1.op.size()+s2.op.size());
for(int i=0;i<s1.op.size();i++) printf("%d %d\n",s1.op[i].fi,s1.op[i].se);
for(int i=(int)(s2.op.size())-1;~i;i--) printf("%d %d\n",s2.op[i].fi,s2.op[i].se);
return 0;
}

Codeforces 512E - Fox And Polygon(构造)的更多相关文章

  1. Educational Codeforces Round 10 B. z-sort 构造

    B. z-sort 题目连接: http://www.codeforces.com/contest/652/problem/B Description A student of z-school fo ...

  2. Codeforces 707C Pythagorean Triples(构造三条边都为整数的直角三角形)

    题目链接:http://codeforces.com/contest/707/problem/C 题目大意:给你一条边,问你能否构造一个包含这条边的直角三角形且该直角三角形三条边都为整数,能则输出另外 ...

  3. CodeForces 388A Fox and Box Accumulation (模拟)

    A. Fox and Box Accumulation time limit per test:1 second memory limit per test:256 megabytes Fox Cie ...

  4. Codeforces 1246D/1225F Tree Factory (构造)

    题目链接 https://codeforces.com/contest/1246/problem/D 题解 首先考虑答案的下界是\(n-1-dep\) (\(dep\)为树的深度,即任何点到根的最大边 ...

  5. Codeforces - 1202D - Print a 1337-string... - 构造

    https://codeforces.com/contest/1202/problem/D 当时想的构造是中间两个3,然后前后的1和7组合出n,问题就是n假如是有一个比较大的质数因子或者它本身就是质数 ...

  6. Codeforces 388C Fox and Card Game (贪心博弈)

    Codeforces Round #228 (Div. 1) 题目链接:C. Fox and Card Game Fox Ciel is playing a card game with her fr ...

  7. Codeforces 743C - Vladik and fractions (构造)

    Codeforces Round #384 (Div. 2) 题目链接:Vladik and fractions Vladik and Chloe decided to determine who o ...

  8. Codeforces 1368E - Ski Accidents(构造+思维)

    Codeforces 题面传送门 & 洛谷题面传送门 神仙构造题(不过可能我构造太烂了?) 首先考虑这个奇奇怪怪的 \(\dfrac{4}{7}\),以及这个每个点出度最多为 \(2\) 的条 ...

  9. Codeforces 1270E - Divide Points(构造+奇偶性)

    Codeforces 题目传送门 & 洛谷题目传送门 显然,直接暴力枚举是不可能的. 考虑将点按横纵坐标奇偶性分组,记 \(S_{i,j}=\{t|x_t\equiv i\pmod{2},y_ ...

随机推荐

  1. Beta_Scrum Meeting_0

    日期:2021年5月26日 参会人员:cy.hcc.lsc.dxh 会议主题:为Beta阶段最早两日的开发制定目标 一.进度情况 组员 负责 两日内完成的任务 接下来两日预计完成的任务 hcc 前端 ...

  2. “妈妈再也不用担心我忘交作业了!”——记2020BUAA软工团队项目选择

    写在前面 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任建) 这个作业的要求在哪里 团队项目选择 项目简介 项目名称:北航学生资源整合和作业提醒平台 项目内容: 设计实现一 ...

  3. 运维常用python库&模块

    sutil:是一个跨平台库(https://github.com/giampaolo/psutil)能够实现获取系统运行的进程和系统利用率(内存,CPU,磁盘,网络等),主要用于系统监控,分析和系统资 ...

  4. Spring Security Jwt Token 自动刷新

    token的自动刷新 一.功能需求 二.功能分析 1.token 的生成 2.token 的自动延长 3.系统资源的保护 4.用户如何传递 token 三.实现思路 1.生成 token 和 refr ...

  5. mongodb的简单查询

    此篇文章简单的记录一下mongodb 的简单查询操作. 一.数据准备: db.persons.insertMany([ {'userId':1,name:'张三','age':20,'scores': ...

  6. vim 删除 替换

    1,删除包含pattern的某一行 :g/pattern/d 或 :%g/pattern/d 2,删除不包含pattern的某一行 :v/pattern/d 或 :g!/pattern/d 3,替换 ...

  7. Python import commands ImportError: No module named 'commands'

    ImportError: No module named 'commands' 在Python3中执行shell脚本,想要获取其执行状态和标准输出.错误输出 的数据,遇到这个错误,原因是command ...

  8. hdu 3038 How Many Answers Are Wrong(并查集)

    题意: N和M.有N个数. M个回答:ai, bi, si.代表:sum(ai...bi)=si.如果这个回答和之前的冲突,则这个回答是假的. 问:M个回答中有几个是错误的. 思路: 如果知道sum( ...

  9. hdu 1506 Largest Rectangle in a Histogram(DP)

    题意: 有一个柱状图,有N条柱子.每一条柱子宽度都为1,长度为h1...hN. 在这N条柱子所构成的区域中找到一个最大面积,每平方米3块钱,问最多赚多少钱. 输入: 1<=N<=10000 ...

  10. UVA 10004 Bicoloring(DFS染色)

    题意: 给N个点构成的无环无向图,并且保证所有点对都是连通的. 给每个点染色,要么染成黑要么染成白.问是否存在染色方案使得所有有边相连的点对颜色一定不一样. 是输出 BICOLORABLE 否则输出 ...