zoukankan      html  css  js  c++  java
  • 洛谷P3958 奶酪

    题目链接
    这道题貌似可以用BFS来写吧qwq。
    我用的是并查集,把联通的洞合并在同一个几何中,最后只需要判断是否存在上表面和下表面有相同集合的洞即可。
    但是需要注意的是还有这样的一种情况:有一个大洞贯穿了整个奶酪所以要对n=1时进行特判。
    AC代码如下:

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #include<cmath>
    #include<algorithm>
    #define MAXN 10010
    using namespace std;
    struct item
    {
        int u;
        double x;
        double y;
        double z;
        int f;
    }chs[MAXN];
    
    bool book1[MAXN],book2[MAXN];
    int f[MAXN];
    
    int find(int k)
    {
        if(f[k]==k) return k;
        else return f[k]=find(f[k]);
    }
    int main()
    {
        int t;
        scanf("%d",&t);
        while(t--)
        {
            memset(book1,0,sizeof(book1));
            memset(book2,0,sizeof(book2));
            int n,h,r;
            scanf("%d%d%d",&n,&h,&r);
        for(int i=1;i<=n;i++)
        {
            int x,y,z;
            scanf("%d%d%d",&x,&y,&z);
            chs[i].u=i;
            chs[i].x=x;
            chs[i].y=y;
            chs[i].z=z;
            chs[i].f=i;
            f[i]=i;
        }
        for(int i=1;i<=n;i++)
        {
            for(int j=i+1;j<=n;j++)
            {
                int p=find(i);
                int c=find(j);
                double dis=sqrt((chs[i].x-chs[j].x)*(chs[i].x-chs[j].x)+(chs[i].y-chs[j].y)*(chs[i].y-chs[j].y)+(chs[i].z-chs[j].z)*(chs[i].z-chs[j].z));
    //            printf("dis=%f
    ",dis);
    			if(dis<=2*r)
                {
                    if(p==c) continue;
                    else
                    {
                        f[p]=c;
                        chs[p].f=c;
                    }
                }
                
            }
        }
        for(int i=1;i<=n;i++)
        {
            if(chs[i].z>=(h-r)&&chs[i].z<=h) book1[i]=1;
        }
        for(int i=1;i<=n;i++)
        {
            if(chs[i].z>=0&&chs[i].z<=r) book2[i]=1;
            
        }
        
        bool sign=0;
        if(n==1)
        {
        	if(2*r>=h&&chs[n].z-r<=0&&chs[n].z+r>=h) 
        	{
        		printf("Yes
    ");
        		continue;
    		}
    		else
    		{
    			printf("No
    ");
    			continue;
    		}
    	}
        for(int i=1;i<=n;i++)
        {
            for(int j=i+1;j<=n;j++)
            {
    //        	printf("f[%d]=%d ,find[%d]=%d,",i,find(i),j,find(j));
                if(book1[i]&&book2[j]&&(find(i)==find(j))&&!sign) 
                {
                    sign=1;
    //                printf("i=%d,j=%d
    ",i,j);
                    printf("Yes
    ");
                }
                if(book1[j]&&book2[i]&&(find(i)==find(j))&&!sign) 
                {
                    sign=1;
    //                printf("i=%d,j=%d
    ",i,j);
                    printf("Yes
    ");
                }
            }
        }
        if(!sign) printf("No
    ");
        }
        return 0;
    }
    
    
  • 相关阅读:
    函数传参总结
    集合操作总结
    深浅拷贝总结
    三级列表展示
    文件操作总结
    vue-router之嵌套路由
    vue-router之动态路由
    Sublime编辑VUE实现代码高亮
    Windows系统下Vue开发环境搭建详解版
    C#调用快递鸟电子面单API实现批量打印电子面单功能
  • 原文地址:https://www.cnblogs.com/LITTLESUNwl/p/10772241.html
Copyright © 2011-2022 走看看