首页 数据库 mysql教程 POJ 2723 Get Luffy Out(2

POJ 2723 Get Luffy Out(2

Jun 07, 2016 pm 03:48 PM
get out

POJ 2723 Get Luffy Out(2-SAT) http://poj.org/problem?id=2723 题意: 你手里有2n把不同的钥匙,这2n把钥匙被分为n对,每对由两个不同的钥匙组成.现在按顺序出现了M个门,每个门上有两个锁,你只需打开其中一个锁就可以打开这个门.现在你需要用你手里的钥匙去按

POJ 2723 Get Luffy Out(2-SAT)

http://poj.org/problem?id=2723

题意:

        你手里有2n把不同的钥匙,这2n把钥匙被分为n对,每对由两个不同的钥匙组成.现在按顺序出现了M个门,每个门上有两个锁,你只需打开其中一个锁就可以打开这个门.现在你需要用你手里的钥匙去按顺序打开门,但是对于属于同一组的两把钥匙,如果你用了钥匙A,那么以后永远不能再用钥匙B了.问你按顺序最多能打开多少个门?

分析:

        首先有2n把钥匙,所以每个钥匙对应两个节点:用or 不用.

        对于同一组的两把钥匙a与b来说: (a=0表示钥匙a选,a=1表示钥匙a不选)

a 用 -> b不用即 a=0 -> b=1

b 用-> a 不用即 b=0 -> a=1

        对于一个具有锁(钥匙)a与锁(钥匙)b的门来说,两个锁我们至少要选1个,所以有边: a=1->b=0 和 b=1->a=0.

        这样我们通过枚举我们能顺序打开的门数目num,我们令num=5时,添加前5条锁生成的边,看看该2-SAT问题是否有解即可.如果num=5有解,就尝试num=6. 如果num=5误解,那么之后更大的num肯定无解.(注意:这个过程要初始化mark标记数组)

AC代码: (未二分答案,如果用二分,应该能更快)

#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
using namespace std;
const int maxn=2000+100;
struct TwoSAT
{
    int n;
    vector<int> G[maxn*2];
    int S[maxn*2],c;
    bool mark[maxn*2];

    bool dfs(int x)
    {
        if(mark[x^1]) return false;
        if(mark[x]) return true;
        mark[x]=true;
        S[c++]=x;
        for(int i=0;i<g if return false true void init n this->n=n;
        for(int i=0;i0) mark[S[--c]]=false;
                if(!dfs(i+1)) return false;
            }
        }
        return true;
    }
}TS;
int main()
{
    int n,m;
    while(scanf("%d%d",&amp;n,&amp;m)==2&amp;&amp;n)
    {
        TS.init(n*2);
        for(int i=0;i<n int a scanf ts.add_clause i for memset if break num="i;" printf return><br>
<br>


</n></g></int></algorithm></vector></cstring></cstdio>
登录后复制
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用PowerShell自动执行任务 如何使用PowerShell自动执行任务 Feb 20, 2024 pm 01:51 PM

如何使用PowerShell自动执行任务

主板上的数字音频输出接口-SPDIF OUT 主板上的数字音频输出接口-SPDIF OUT Jan 14, 2024 pm 04:42 PM

主板上的数字音频输出接口-SPDIF OUT

out和in接口是什么意思 out和in接口是什么意思 Sep 28, 2021 pm 04:39 PM

out和in接口是什么意思

java如何发起http请求调用post与get接口 java如何发起http请求调用post与get接口 May 16, 2023 pm 07:53 PM

java如何发起http请求调用post与get接口

Curl Get命令的示例 Curl Get命令的示例 Mar 20, 2024 pm 06:56 PM

Curl Get命令的示例

如何更改Ubuntu的apt-get更新源? 如何更改Ubuntu的apt-get更新源? Jan 05, 2024 pm 03:40 PM

如何更改Ubuntu的apt-get更新源?

深入解析jQuery中get方法和post方法的异同 深入解析jQuery中get方法和post方法的异同 Feb 24, 2024 pm 12:15 PM

深入解析jQuery中get方法和post方法的异同

win10系统闪退显示out of memory怎么办? win10系统闪退显示out of memory怎么办? Feb 09, 2024 pm 03:00 PM

win10系统闪退显示out of memory怎么办?

See all articles