题目内容请点击上面链接查看(能够看到这里的应该都是看过题目的)
方法:使用dfs,每次dfs将一块垃圾删除,然后计数一次,等所有的点都删除之后就得出了垃圾的个数。
注意的地方:
1.内存限制。
不能开一个二维数组来保存桌面的情况,这样会超出题目的内存限制。
所以可以用set来模拟一个二维数组。
AC代码:
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int M=1e6+100;
set<pair<int,int> > mp;
set<pair<int,int> >::iterator it;
int a[M][2];
int dir[8][2]= {{-1,0},{-1,1},{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1}};
void dfs(int x,int y)
{
mp.erase(make_pair(x,y));
for(int i=0;i<8;i++)
{
int tx=x+dir[i][0],ty=y+dir[i][1];
if(mp.count(make_pair(tx,ty))==1)
dfs(tx,ty);
}
}
int main()
{
int n;
scanf("%d",&n);
for(int i=0; i<n; i++)
{
scanf("%d%d",&a[i][0],&a[i][1]);
mp.insert(make_pair(a[i][0],a[i][1]));
}
int ans=0;
while(!mp.empty()){
it=mp.begin();
dfs(it->first,it->second);
ans++;
}
printf("%d\n",ans);
return 0;
}
博客介绍了解决某题的方法,使用dfs每次删除一块垃圾并计数,最终得出垃圾个数。同时提到要注意内存限制,不能用二维数组保存桌面情况,可用set模拟二维数组,还给出了AC代码。
186

被折叠的 条评论
为什么被折叠?



