3149: [Ctsc2013]复原

Time Limit: 10 Sec  Memory Limit: 128 MBSec  Special Judge
Submit: 95  Solved: 44
[Submit][Status][Discuss]

Description

在几何课上,老师画了一个圆,圆上有很多条弦,这些弦两两不重合,但是 有些是相交的。你本想把图临摹下来回家好好研究,可惜下课后,图被值日生 擦掉了。幸运的是,你准确地记录了弦的数量和弦的相交情况。
现在,你想尽量复原这张图。同时你还想知道,最多能选出多少条弦,使得 选出来的弦两两不相交。

Input

第一行包含2个正整数n,m,分别表示弦的条数以及相交弦的对数,所有的弦从1至n编号。接下来 m行每行两个正整数a,b,表示第a条弦与第b条弦相交。

Output

输出分为两行。
第一行输出2n个正整数,按逆时针方向给出满足题意的圆上每条弦的两个
端点的相对顺序,其中第i条弦的两个端点均用数字i来表示。
第二行输出1个正整数,表示最多能选多少条两两不相交的弦。

Sample Input

5 6
1 2
1 3
2 3
2 4
3 5
4 5

Sample Output

1 2 3 1 4 2 5 4 3 5
2

HINT

1<=N<=20 1<=M<=40

Source

[

//表示只会10分暴力
//对大神的位运算优化膜拜。
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
const int N=;
const int M=1.5e6+;
int n,m,len,cnt,bin[N],lg[M],f[M],q[N],mp[N],pth[N<<],ans[N<<];
bool a[N][N],vis[N];int sum,end;
inline void Max(int &x,int y){if(x<y) x=y;}
bool dfs(int k,int goal){
if(k>goal) return ;
len++;
for(int i=len;i;i--) pth[i]=pth[i-];
for(int i=;i<=len;i++){
pth[i]=k;len++;
for(int j=len;j>i+;j--) pth[j]=pth[j-];
for(int j=i+,s=;j<=len;j++){
pth[j]=k;
if(!(s^mp[k]) && dfs(k+,goal)) return ;
pth[j]=pth[j+];
s^=bin[pth[j]-];
}
len--;pth[i]=pth[i+];
}
len--;
return ;
}
int bfs(int S){
int h=,t=;len=;q[t]=S;vis[S]=;
while(h!=t){
int x=q[++h];
for(int i=;i<=n;i++){
if(!vis[i] && a[x][i]){
vis[i]=;
q[++t]=i;
}
}
}
for(int j=;j<=t;j++){
mp[j]=;
for(int k=;k<j;k++){
if(a[q[j]][q[k]]) mp[j]|=bin[k-];
}
}
return t;
}
void work(){
for(int i=;i<=len;i++) ans[++cnt]=q[pth[i]];
for(int i=;i<=end;i++){
mp[i]=bin[i-];
for(int j=;j<=end;j++){
if(a[q[i]][q[j]]){
mp[i]|=bin[j-];
}
}
}
int mx=,tot=bin[end]-;
memset(f,,sizeof f);
for(int j=tot,x;j;j--){
mx=max(mx,f[j]);
for(int k=j;k;k^=x){
x=k&-k;
Max(f[j&(tot^mp[lg[x]+])],f[j]+);
}
}
sum+=max(mx,f[]);
}
int main(){
scanf("%d%d",&n,&m);
for(int i=,x,y;i<=m;i++) scanf("%d%d",&x,&y),a[x][y]=a[y][x]=;
for(int i=;i<=n;i++) bin[i]=<<i;
for(int i=;i<=bin[n];i++) lg[i]=lg[i>>]+;
for(int i=;i<=n;i++) if(!vis[i]){
end=bfs(i);
dfs(,end);
work();
}
for(int i=;i<=cnt;i++) printf("%d%c",ans[i],(i<cnt)?' ':'\n');
printf("%d\n",sum);
return ;
}

3149: [Ctsc2013]复原的更多相关文章

  1. BZOJ3149 CTSC2013 复原 搜索

    传送门 \(N \leq 20\)很适合暴搜-- 第二问最大独立集裸题,\(O(2^NN)\)的算法都能过-- 考虑第一问,使用搜索寻找可行解 每一次枚举一条弦的两个端点,通过位运算计算与其相交的弦的 ...

  2. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  3. UWP开发之Mvvmlight实践五:SuspensionManager中断挂起以及复原处理

    最近比较忙有一段时间没有更新了,再接再厉继续分享. 案例下载:https://github.com/NewBLife/UWP/tree/master/SuspendSample 先我们看看App在生命 ...

  4. [LeetCode] Recover Binary Search Tree 复原二叉搜索树

    Two elements of a binary search tree (BST) are swapped by mistake. Recover the tree without changing ...

  5. [LeetCode] Restore IP Addresses 复原IP地址

    Given a string containing only digits, restore it by returning all possible valid IP address combina ...

  6. 程设大作业xjb写——魔方复原

    鸽了那么久总算期中过[爆]去[炸]了...该是时候写写大作业了 [总不能丢给他们不会写的来做吧 一.三阶魔方的几个基本定义 ↑就像这样,可以定义面的称呼:上U下D左L右R前F后B UD之间的叫E,LR ...

  7. 爱改名的小融 2(codevs 3149)

    3149 爱改名的小融 2  时间限制: 2 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description Wikioi上有个人 ...

  8. AppDelegate关于应用程序挂起、复原与终止的代理方法

    AppDelegate关于应用程序挂起.复原与终止的代理方法: 首次运行: - (BOOL)application:(UIApplication *)application didFinishLaun ...

  9. 力扣算法题—093复原IP地址

    给定一个只包含数字的字符串,复原它并返回所有可能的 IP 地址格式. 示例: 输入: "25525511135" 输出: ["255.255.11.135", ...

随机推荐

  1. 奇妙的go语言(面向对象)

    [ 声明:版权全部.欢迎转载,请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 有过C++语言学习经历的朋友都知道.面向对象主要包含了三个基本特征:封装.继承和多态.封装,就 ...

  2. 实现整数转化为字符串函数itoa()函数

    函数原型: char *itoa( int value, char *string,int radix);原型说明:value:欲转换的数据.string:目标字符串的地址.radix:转换后的进制数 ...

  3. 又一个错误" Fatal error: Call to undefined function myabp_print_screenshot_all() "

    xxx ( ! ) Fatal error: Call to undefined function myabp_print_screenshot_all() in D:\wamp\www\wp-con ...

  4. js学习笔记15----子节点和兄弟节点的操作

    1.元素.firstChild : 只读属性,第一个子节点 标准下:会包含文本类型的子节点. 非标准下:只包含元素类型子节点. 元素.firstElementChild : 只读属性,第一个元素子节点 ...

  5. js学习笔记11----表单操作

    1.复选框选中 var aInput = document.getElementsByTagname('input'); aInput[0].checked=true;

  6. android DVM

    android 运行环境主要是虚拟机技术:Dalvik.每一个Android应用程序都在它自己的进程中运行,都拥有一个独立的 Dalvik虚拟机实例.而每一个DVM都是在Linux中的一个进程,所以说 ...

  7. bson.errors.InvalidStringData: strings in documents must be valid UTF-8

    场景: pymongo 查询数据库的时候报错. for gscode in GSList_StockPool_Mongo_MktStop: self._collection_flash.find({& ...

  8. Web 服务器配置

    Web 服务器配置在您进行 CGI 编程之前,请确保您的 Web 服务器支持 CGI,并已配置成可以处理 CGI 程序.所有由 HTTP 服务器执行的 CGI 程序,都必须在预配置的目录中.该目录称为 ...

  9. Js注释和对象

    1.注释 单行: //注释内容 console.log('加油~');//在控制台输出一条信息: 多行: /*注释内容*/: 2.对象 1)对象是一个复合值,是根据某种引用类型创建出来的实例. 2)常 ...

  10. 如何正确理解javascript的模块化的