一道找朋友的问题

以前写的.....贴出来,题目意思大概是找a,b两个人是否有关系...

 

#include <iostream>
#include <cstring>
using namespace std;
bool Find;
int n,m,flag[30],M[30][30];
void ss(int x,int y)
{
    flag[x]=1;
    for(int i=0;i<=26;i++)
        {
            if(M[x][i]==1&&flag[i]==0) {     //if后面有一个括号,当时忘记了加,想了很久。。。
            if(i==y)  {Find=true;return;}
            ss(i,y);}
        }
        //return Find;
}
int main()
{
    //while(cin>>n>>m)
    cin>>n>>m;
     char x,y;
     memset(M,0,sizeof(M));
    while(n--)
    {
        cin>>x>>y;
        M[x-'A'][y-'A']=1;
        M[y-'A'][x-'A']=1;
    }
    while(m--)
    {
        cin>>x>>y;
        memset(flag,0,sizeof(flag));
        Find=false;
        ss(x-'A',y-'A');
        if(Find==true)  cout<<"Yes\n";
        else cout<<"No\n";
    }

    return 0;
}

//这道题挺经典的,和水池问题有相像之处。。。
题目大概思路是给一个测试数据,里面有几组值,分别是每个字母之间有联系

所以可以用二维数组将有联系的标记为1,然后在调用函数里面进行dps。。。。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值