3935 仙境诅咒

思路:在坐标系中给定一个标准点和范围,判断其他点是否在范围内。     

        

#include <bits/stdc++.h>

using namespace std;
const int N=1e3+9;
int a[N][3];
int n,D;
int vis[N]={0};

void dfs(int num)//"锤子"
{
  vis[num]=1;//当前数已经被看过

  for(int i=1;i<=n;i++)//每个数都要对所有数判断
    {
      if(vis[i]) continue;//跳过已经检查过的数
      if((a[num][1]-a[i][1])*(a[num][1]-a[i][1])+(a[num][2]-a[i][2])*(a[num][2]-a[i][2])<=D*D)//判断距离
      {
        dfs(i);//下一个“锤子”
      }
    }
  
}

int main()
{
  cin>>n;
  for(int i=1;i<=n;i++)
    for(int j=1;j<=2;j++)
      cin>>a[i][j];

  cin>>D;
  dfs(1);  

  for(int i=1;i<=n;i++)//最后打印
    cout<<vis[i]<<'\n'; 

  return 0;
}


 因为变量重名导致的错误,还是挺有意义的。

#include<bits/stdc++.h>

using namespace std;
int n,D;
#define x first
#define y second
const int N=1e3+9;
int vis[N];
vector<pair<int,int> > a(N);

void dfs(int num)//这里的num不能使用n,不然变量重名导致运行的错误。
{
  vis[num]=1;

  for(int i=1;i<=n;i++)
  {
    if(vis[i])continue;
    if((a[num].x-a[i].x)*(a[num].x-a[i].x)+(a[num].y-a[i].y)*(a[num].y-a[i].y)<=D*D)
    {
      dfs(i);
    }
  }
}

int main()
{
  cin>>n;
  for(int i=1;i<=n;i++) cin>>a[i].x>>a[i].y;

  cin>>D;

  dfs(1);

  for(int i=1;i<=n;i++) cout<<vis[i]<<'\n';

  return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值