大致题意:
给出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;
}
分享到:
相关推荐
- POJ 3373、POJ 1691:二分查找技术的应用。 ### 动态规划 #### 二维动态规划 - **题目示例**: - POJ 1191、POJ 1054:基于矩阵的状态转移方程。 - POJ 3280、POJ 2029:多维状态空间的探索。 #### 递归动态...
- **匹配算法**:如匈牙利算法(Hungarian Algorithm)。 - **示例题目**: - POJ 1459: 匈牙利算法实践 - POJ 3436: 匈牙利算法变种 ##### 3. 数据结构 - **栈**:适用于后进先出(LIFO)的数据结构。 - **示例...
【标题】"POJ2092:计数排序,求第K大的元素"是一个编程题目,主要涉及计数排序算法以及如何在数组中找出第K大的元素。计数排序是一种非基于比较的排序算法,它适用于整数排序,尤其在数据范围不大的情况下效率极高。...
【标题】"POJ1276-Cash Machine"是一个编程竞赛题目,源自北京大学的在线判题系统POJ(Problem Set of Peking University)。这个题目挑战程序员解决现金自动取款机(ATM)的现金提取问题,涉及到算法设计和实现。 ...
- 提供对排序和查找算法的理解与应用指导,包括快速排序、归并排序、二分查找等经典算法。 4. **贪心算法**: - (poj3295):讲解如何利用贪心策略来解决问题,强调每一步选择都是局部最优解。 5. **动态规划**:...
poj 2206 Magic Multiplying Machine.md
* 哈希表和二分查找等高效查找法:例如 poj3349、poj3274、poj2151、poj1840、poj2002、poj2503。 * 哈夫曼树:例如 poj3253。 * 堆:例如 poj2513。 * trie 树:例如 poj2513。 4. 简单搜索: * 深度优先搜索...
- poj3041: 涉及到二分图匹配问题,适合用匈牙利算法解决。 ##### 6. 最大流的增广路算法 - **定义**: KM 算法是一种用于寻找最大流的方法,特别适用于网络流问题。 - **应用场景**: 常用于资源分配、交通流量优化...
这是西北工业大学的POJ试题的答案,欢迎下载!
北大POJ1276试题代码
#### 2724 Purifying Machine - 二分匹配 - **知识点**:二分匹配算法。 #### 2728 Desert King - 最优比例生成树 - **知识点**:最优比例生成树问题,类似于最小生成树,但在权重上有所区别。 #### 2749 *...
5. POJ3041: 这个题目的具体描述不完整,但从题目大意上看,它可能涉及到某种形式的匹配问题,比如工作分配或者任务调度,也可能需要用到二分图最大匹配。 在解决这些问题时,通常会使用匈牙利算法(Kuhn-Munkres...
* 哈希表和二分查找等高效查找法:哈希表和二分查找等高效查找法是指解决问题的高效查找算法,如 poj3349、poj3274、POJ2151、poj1840、poj2002、poj2503。 * 哈夫曼树:哈夫曼树是指解决问题的哈夫曼树算法,如 poj...
- **例题**:poj1860, poj3259, poj1062, poj2253, poj1125, poj2240 - **解释**:最短路径算法包括Dijkstra算法、Bellman-Ford算法、Floyd算法以及堆优化的Dijkstra算法等。 ##### (3) 最小生成树算法 - **例题**...
POJ 2703:选择出行方式 **题目概述**: 本题目旨在通过编程的方式解决一个实际问题——选择最佳出行方式(步行或骑自行车)。题目给出了一种算法来决定在不同条件下应该采取哪种出行方式。 **代码解析**: - **...
根据提供的信息,我们可以将POJ(Peking Online Judge)平台上的算法题目按照不同的类别进行整理与解析。这对于希望系统性地提高自己算法能力的学习者来说非常有用。下面将基于给出的分类来详细介绍每一类算法的核心...
网上整理的一些poj刷题指南。 poj地址:http://poj.org
- **哈希表和二分查找**:提高查找效率,如poj3349,用于快速定位元素。 - **哈夫曼树**:压缩编码,如poj3253。 - **堆**:如优先队列,用于实现最大值或最小值的快速访问。 - **trie树**:用于高效字符串查询...
### ACM新手刷题攻略之POJ ... - 推荐题目:[poj1860](https://vjudge.net/problem/POJ-1860)、[poj3259](https://vjudge.net/problem/POJ-3259)、[poj1062](https://vjudge.net/problem/POJ-1062)、[poj2253]...
- 二分图的最大匹配:如匈牙利算法,用于解决二分图的匹配问题,如`poj3041, poj3020`。 - **数据结构** - 字符串处理:如KMP算法和后缀数组,用于字符串搜索和模式匹配,如`poj1035, poj3080`。 - 排序算法:如...