데이터 베이스 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으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 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 요청을 시작하고 게시물을 호출하고 인터페이스를 얻습니까? Java는 어떻게 http 요청을 시작하고 게시물을 호출하고 인터페이스를 얻습니까? May 16, 2023 pm 07:53 PM

Java는 어떻게 http 요청을 시작하고 게시물을 호출하고 인터페이스를 얻습니까?

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 시스템이 충돌하고 메모리 부족이 표시되면 어떻게 해야 합니까? win10 시스템이 충돌하고 메모리 부족이 표시되면 어떻게 해야 합니까? Feb 09, 2024 pm 03:00 PM

win10 시스템이 충돌하고 메모리 부족이 표시되면 어떻게 해야 합니까?

See all articles