`
暴风雪
  • 浏览: 390779 次
  • 性别: Icon_minigender_2
  • 来自: 杭州
社区版块
存档分类
最新评论

[二分匹配]poj 2724:Purifying Machine

阅读更多

大致题意:

    给出m串长度为n的01串。有些串中可能包含*,这样的串可以表示两个串,*为1 和*为0。重复的算一种。比如题目中

*01

100

011

就代表了四个01串

001

101

100

011

现在我们需要消灭掉所有的01串,消灭方式有两种:

1一次消灭一个串。

2如果两个串的差别只有一位的话可以同时消灭这两个串。

 

问最少多少次操作可以消灭所有的01串

 

大致思路:
   按照串中1的个数的奇偶性把串分为两个集合,因为1的个数的奇偶性相同的两个串之间的差别数必然大于1。想到这里接下来就简单了。(吐槽,从昨晚wrong到现在,真心被wa到内伤了,不过ac的感觉很爽啊)

 

 

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
const int nMax=(1<<11)+10;
bool used[nMax];
int num[nMax],cnt;
char str[100];
bool map[nMax][nMax],vis[nMax];
int linkk[nMax],n,m,dd;

int dfs(int s){
    for(int i=0;i<cnt;i++){
        if(!vis[i]&&map[s][i]){
            vis[i]=1;
            if(linkk[i]==-1||dfs(linkk[i])){
                linkk[i]=s;
                return 1;
            }
        }
    }
    return 0;
}

void solve(int len){
    int i,a,b,c;
    a=b=c=0;
    for(i=0;i<len;i++){
        a<<=1;
        b<<=1;
        if(str[i]=='*'){
            a+=0;
            b+=1;
            c=1;
        }
        else{
            a+=str[i]-'0';
            b+=str[i]-'0';
        }
    }
    if(!used[a]){
      //  cout<<a<<endl;
        used[a]=1;
        num[cnt++]=a;
    }
    if(!used[b]){
   //     cout<<b<<endl;
        used[b]=1;
        num[cnt++]=b;
    }
}

//检查一个数的二进制中1的个数
int judge(int fuck){   
    int a=0;
    while(fuck){
        if(fuck&1)a++;
        fuck>>=1;
    }
    if(a&1)return 1;
    return 0;
}

void initmap(int nn){
    int i,j,a,b,c;
    memset(map,0,sizeof(map));
    for(i=0;i<cnt;i++){
        if(judge(num[i]))continue;
        for(j=0;j<cnt;j++){
            if(!judge(num[j]))continue;
            a=num[i]^num[j];
            if(a&&((a&(a-1))==0)){
                map[i][j]=1;
            }
        }
    }
}

int main(){
    int N,M,i,j,ans;
    while(scanf("%d%d",&N,&M)!=EOF&&(N||M)){
        cnt=0;
        memset(used,0,sizeof(used));
        for(i=1;i<=M;i++){
            scanf("%s",str);
            solve(N);
        }
        initmap(N);
        n=m=1<<(N);
        ans=0;
        memset(linkk,-1,sizeof(linkk));
        for(i=0;i<cnt;i++){
            memset(vis,0,sizeof(vis));
            if(dfs(i))ans++;
        }
        printf("%d\n",cnt-ans);
    }
    return 0;
}
0
0
分享到:
评论

相关推荐

    经典 的POJ 分类

    - POJ 3373、POJ 1691:二分查找技术的应用。 ### 动态规划 #### 二维动态规划 - **题目示例**: - POJ 1191、POJ 1054:基于矩阵的状态转移方程。 - POJ 3280、POJ 2029:多维状态空间的探索。 #### 递归动态...

    acm新手训练方案新手必备

    - **匹配算法**:如匈牙利算法(Hungarian Algorithm)。 - **示例题目**: - POJ 1459: 匈牙利算法实践 - POJ 3436: 匈牙利算法变种 ##### 3. 数据结构 - **栈**:适用于后进先出(LIFO)的数据结构。 - **示例...

    POJ2092:计数排序,求第K大的元素

    【标题】"POJ2092:计数排序,求第K大的元素"是一个编程题目,主要涉及计数排序算法以及如何在数组中找出第K大的元素。计数排序是一种非基于比较的排序算法,它适用于整数排序,尤其在数据范围不大的情况下效率极高。...

    POJ1276-Cash Machine

    【标题】"POJ1276-Cash Machine"是一个编程竞赛题目,源自北京大学的在线判题系统POJ(Problem Set of Peking University)。这个题目挑战程序员解决现金自动取款机(ATM)的现金提取问题,涉及到算法设计和实现。 ...

    acm训练计划(poj的题)

    - 提供对排序和查找算法的理解与应用指导,包括快速排序、归并排序、二分查找等经典算法。 4. **贪心算法**: - (poj3295):讲解如何利用贪心策略来解决问题,强调每一步选择都是局部最优解。 5. **动态规划**:...

    poj 2206 Magic Multiplying Machine.md

    poj 2206 Magic Multiplying Machine.md

    poj题目分类

    * 哈希表和二分查找等高效查找法:例如 poj3349、poj3274、poj2151、poj1840、poj2002、poj2503。 * 哈夫曼树:例如 poj3253。 * 堆:例如 poj2513。 * trie 树:例如 poj2513。 4. 简单搜索: * 深度优先搜索...

    ACM北大训练

    - poj3041: 涉及到二分图匹配问题,适合用匈牙利算法解决。 ##### 6. 最大流的增广路算法 - **定义**: KM 算法是一种用于寻找最大流的方法,特别适用于网络流问题。 - **应用场景**: 常用于资源分配、交通流量优化...

    POJ1-7试题

    这是西北工业大学的POJ试题的答案,欢迎下载!

    北大POJ1276-Cash Machine

    北大POJ1276试题代码

    poj图论题目汇总

    #### 2724 Purifying Machine - 二分匹配 - **知识点**:二分匹配算法。 #### 2728 Desert King - 最优比例生成树 - **知识点**:最优比例生成树问题,类似于最小生成树,但在权重上有所区别。 #### 2749 *...

    二分图匹配题解1

    5. POJ3041: 这个题目的具体描述不完整,但从题目大意上看,它可能涉及到某种形式的匹配问题,比如工作分配或者任务调度,也可能需要用到二分图最大匹配。 在解决这些问题时,通常会使用匈牙利算法(Kuhn-Munkres...

    POJ算法题目分类

    * 哈希表和二分查找等高效查找法:哈希表和二分查找等高效查找法是指解决问题的高效查找算法,如 poj3349、poj3274、POJ2151、poj1840、poj2002、poj2503。 * 哈夫曼树:哈夫曼树是指解决问题的哈夫曼树算法,如 poj...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    - **例题**:poj1860, poj3259, poj1062, poj2253, poj1125, poj2240 - **解释**:最短路径算法包括Dijkstra算法、Bellman-Ford算法、Floyd算法以及堆优化的Dijkstra算法等。 ##### (3) 最小生成树算法 - **例题**...

    poj部分水题代码

    POJ 2703:选择出行方式 **题目概述**: 本题目旨在通过编程的方式解决一个实际问题——选择最佳出行方式(步行或骑自行车)。题目给出了一种算法来决定在不同条件下应该采取哪种出行方式。 **代码解析**: - **...

    poj上算法题目分类

    根据提供的信息,我们可以将POJ(Peking Online Judge)平台上的算法题目按照不同的类别进行整理与解析。这对于希望系统性地提高自己算法能力的学习者来说非常有用。下面将基于给出的分类来详细介绍每一类算法的核心...

    poj刷题指南

    网上整理的一些poj刷题指南。 poj地址:http://poj.org

    POJ题目简单分类(ACM)

    - **哈希表和二分查找**:提高查找效率,如poj3349,用于快速定位元素。 - **哈夫曼树**:压缩编码,如poj3253。 - **堆**:如优先队列,用于实现最大值或最小值的快速访问。 - **trie树**:用于高效字符串查询...

    acm新手刷题攻略之poj

    ### ACM新手刷题攻略之POJ ... - 推荐题目:[poj1860](https://vjudge.net/problem/POJ-1860)、[poj3259](https://vjudge.net/problem/POJ-3259)、[poj1062](https://vjudge.net/problem/POJ-1062)、[poj2253]...

    POJ入门题库(含解题思路和答案)

    17. POJ——2707 求一元二次方程的根:涉及到基础的代数知识,如使用求根公式解决一元二次方程。 18. POJ——2714 求平均年龄:可能需要处理年龄数据并计算平均值,涉及到数据处理和统计计算。 19. POJ——2715 谁...

Global site tag (gtag.js) - Google Analytics