原题解链接:https://ac.nowcoder.com/discuss/150007

暴力

#define _CRT_SECURE_NO_DEPRECATE
/************************
*创建时间:2018 09 14
*文件类型:源代码文件
*题目来源:原创题
*当前状态:已通过
*备忘录:最小点覆盖 标程
*作者:HtBest
************************/
#include <stdio.h>
#include <iostream>
#include <string>
#include <stdlib.h>
#include <string.h>
#include <algorithm>
#include <queue>
#include <bitset>
// #include <sys/wait.h>
// #include <sys/types.h>
// #include <unistd.h>
using namespace std;
#define MAXN 2002
int n,m,head[MAXN],to[MAXN],_edge,visY[MAXN],visX[MAXN],march[MAXN];
char map[MAXN][MAXN];
struct EDGE 
{
	int a,b,next;
	EDGE(int a=0,int b=0,int next=0):a(a),b(b),next(next){}
}edge[100001];
/* Variable explain:

*/
void adde(int a,int b)
{
	edge[++_edge]=EDGE(a,b,head[a]);
	head[a]=_edge;
	// printf("%d %d\n",a,b);
}
void read()
{
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;++i)
	{
		scanf("%s",map[i]+1);
		for(int j=1;j<=m;++j)
		{
			if(map[i][j]=='*')adde(i,j);
		}
	}
	return;
}
bool find(int a)
{
	visX[a]=true;
	for(int i=head[a];i;i=edge[i].next)
	{
		int b=edge[i].b;
		if(visY[b])continue;
		visY[b]=1;
		if(!to[b]||find(to[b]))
		{
			to[b]=a;
			return march[a]=true;
		}
	}
	return false;
}
void solve()
{
	int ans=0,ls1=0;
	for(int i=1;i<=n;++i)
	{
		for(int j=1;j<=m;++j)visY[j]=0;
		ans+=find(i);
	}
	printf("%d\n",ans);
	for(int i=1;i<=m;++i)visY[i]=0;
	for(int i=1;i<=n;++i)visX[i]=0;
	for(int i=1;i<=n;++i)if(!march[i])find(i);
	for(int i=1;i<=n;++i)if(!visX[i])++ls1;
	printf("%d ",ls1);
	for(int i=1;i<=n;++i)if(!visX[i])printf("%d ",i);
	printf("\n%d ",ans-ls1);
	for(int i=1;i<=m;++i)if(visY[i])printf("%d ",i);puts("");
}
int main()
{
	read();
	solve();
	return 0;
}