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. Spring - BeanFactory 新旧工厂差异

    在将要被加入到spring容器中的service中,添加static静态代码块(加载类时被调用),用于判断spring中新旧bean工厂的加载性质. package com.witwicky.serv ...

  2. 【转】WCF入门教程五[WCF的通信模式]

    一.概述 WCF在通信过程中有三种模式:请求与答复.单向.双工通信.以下我们一一介绍. 二.请求与答复模式 描述: 客户端发送请求,然后一直等待服务端的响应(异步调用除外),期间处于假死状态,直到服务 ...

  3. oop-Inheritance & Polymorphism

    本文主要作为java学习笔记,方便以后查看,大部分内容都源于以下网站: http://www.ntu.edu.sg/home/ehchua/programming/index.html#Game 本文 ...

  4. e646. 处理鼠标点击事件

    component.addMouseListener(new MyMouseListener()); public class MyMouseListener extends MouseAdapter ...

  5. C++ 数据抽象

    C++ 数据抽象数据抽象是指,只向外界提供关键信息,并隐藏其后台的实现细节,即只表现必要的信息而不呈现细节. 数据抽象是一种依赖于接口和实现分离的编程(设计)技术. 让我们举一个现实生活中的真实例子, ...

  6. Android APK反编译详解(附图) (转至 http://blog.csdn.net/ithomer/article/details/6727581)

    本文Android反编译教程,测试环境: Win7 Ultimate x64 Ubuntu 12.04 x86_x64 反编译工具包 下载 (2012-10-10更新) 一.Apk反编译得到Java源 ...

  7. 【复杂】CentOS 6.4下PXE+Kickstart无人值守安装操作系统

    一.简介 1.1 什么是PXE PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持 ...

  8. 获取作为 URL 部署清单的位置。

    ActivationContext ac = AppDomain.CurrentDomain.ActivationContext; ApplicationIdentity ai = ac.Identi ...

  9. 【Java面试题】16 静态代码块,main方法,构造代码块,构造方法

    public class HelloB extends HelloA{ public HelloB() { System.out.println("HelloB"); } { Sy ...

  10. 【java】java设计模式(5):原型模式(Prototype)

    原型模式虽然是创建型的模式,但是与工程模式没有关系,从名字即可看出,该模式的思想就是将一个对象作为原型,对其进行复制.克隆,产生一个和原对象类似的新对象.本小结会通过对象的复制,进行讲解.在Java中 ...