首页 > 其他 > 详细

剪邮票

时间:2019-02-03 21:47:51      阅读:156      评论:0      收藏:0      [点我收藏+]

题目: 
如【图1.jpg】, 有12张连在一起的12生肖的邮票。 
现在你要从中剪下5张来,要求必须是连着的。 (仅仅连接一个角不算相连) 
比如,【图2.jpg】,【图3.jpg】中,粉红色所示部分就是合格的剪取。

技术分享图片

技术分享图片

技术分享图片

 

答案是:116

思路:这题说实话刚开始懵了,DFS吧 感觉并不是,因为深搜的话 选一个就往回走了,感觉不是。  然后再想别的办法 ,果然蓝桥杯的题目暴力很强大,暴力出奇迹真没错。。  我就是暴力过的。。。

但是如果真的是比赛现场,哪里来的那么久的时间做呢?  做了一个多小时吧  主要是找BUg   找了很久。  总结一下,蓝桥杯一定要自己验证一下自己代码是否正确,就算验证不了,也把结果输出来看看

至少输出来的结果保证都是对的   !!!  切记!!  这也花不了多少时间  但是却能很大程度提高正确率  个人认为很不错!!!

好了 不讲废话了   思路是  : 题目就1-12个数字  你选择五个数字出来暴力,所有情况也不多计算机一秒内跑出来足够了 。  你先选出5个数字 判断这五个数字是否符合条件   判断条件也是暴力

只要人一个数字和其它数字相差1或者4就是相邻了,但是有特例(4 5  和8 9)特判一下就够了   注意还用了一下并查集,联通的归为一块  最后看是否是一块就好了 

看代码:

#include<iostream>
#include<math.h>
#include<algorithm>
using namespace std;
int a[5];
int node[13];
int ans=0;
void Init()
{
    for(int i=0;i<13;i++) node[i]=i;
}
int Find(int x)
{
    if(x==node[x]) return x;
    return node[x]=Find(node[x]);
}
void Union(int x,int y)
{
    x=Find(x);
    y=Find(y);
    if(x!=y) node[x]=y;
    return ;
}
void judge()
{
    int flag=0;
    Init();
    for(int i=0;i<5;i++)
    {
        flag=0;
        for(int j=0;j<5;j++)
        {
            int z=abs(a[i]-a[j]);
            if((z==1||z==4)&&(!(a[i]==4&&a[j]==5))&&(!(a[i]==8&&a[j]==9))&&(!(a[i]==5&&a[j]==4))&&(!(a[i]==9&&a[j]==8)))
            {
                //&&(!(a[i]==5&&a[j]==4))&&(!(a[i]==9&&a[j]==8))
                //cout<<"**"<<endl;
                Union(a[i],a[j]);
                flag=1;
                //break;
            }
        }
        if(flag==0) return ;
    }
    //for(int i=0;i<5;i++) cout<<a[i];
    //cout<<endl;
    int cnt=Find(a[0]);
    for(int i=0;i<5;i++)
    {
        if(Find(a[i])!=cnt) return ;
    }
//    for(int i=0;i<5;i++) cout<<a[i];
//    cout<<endl;
    ans++;
    return ;
}
int main()
{

    for(int i=1;i<=12;i++)
    {
        a[0]=i;
        for(int j=i+1;j<=12;j++)
        {
            a[1]=j;
            for(int k=j+1;k<=12;k++)
            {
                a[2]=k;
                for(int l=k+1;l<=12;l++)
                {
                    a[3]=l;
                    for(int r=l+1;r<=12;r++)
                    {
                        a[4]=r;
                        judge();
                    }
                }
            }
        }
    }
    cout<<ans<<endl;
    return 0;
}

 

剪邮票

原文:https://www.cnblogs.com/caijiaming/p/10351022.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!