| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 410 人关注过本帖
标题:真的好难
只看楼主 加入收藏
xiexiaoyong
Rank: 1
等 级:新手上路
帖 子:3
专家分:2
注 册:2013-3-18
结帖率:0
收藏
已结贴  问题点数:10 回复次数:4 
真的好难
L型骨牌棋盘覆盖
题目描述
有一个棋盘,要求用给定的四种骨牌进行覆盖。四种骨牌定义如下:


 
给定的棋盘中有一个格子不存在,即不需要覆盖的格子。
输入
输入有多个用例,第一个为用例个数n,接下来每个用例占两行,其中第一行为棋盘大小(如3,表示棋盘大小为2的3次,即8行8列),第二行为两个正整数,表示空缺的格子行号和列号。
输出
每个用例用一行输出各种骨牌的使用数,用一个空格隔开。
样例输入
1
3
1 1
样例输出
9 5 5 2



#include <iostream>
#include <math.h>
using namespace std;

int h1=0,h2=0,h3=0,h4=0;
int a[100][100];

void func(int sr,int sl,int er,int el,int r,int l)
{
    int mr,ml;
    if(er==sr)
        return ;
    mr = (er+sr)/2;
    ml = (el+sl)/2;
    //缺的属于哪一部分
    if(r<=mr)   //上半部分
    {
        if(l<=ml)   //左部分
        {
        //    cout<<"放L1"<<endl;
            h1++;
            a[mr][ml+1] = 1;
            a[mr+1][ml] = 1;
            a[mr+1][ml+1] = 1;
            //递归四次,
            func(sr,sl,mr,ml,r,l);
            func(sr,mr+1,mr,el,mr,ml+1);
            func(ml+1,sl,er,ml,mr+1,ml);
            func(mr+1,ml+1,er,el,mr+1,ml+1);        

        }
        else
        {
            h2++;
        //    cout<<"放L2"<<endl;
            a[mr][ml] = 2;
            a[mr+1][ml] = 2;
            a[mr+1][ml+1] = 2;
            //递归四次,
            func(sr,sl,mr,ml,mr,ml);
            func(sr,mr+1,mr,el,r,l);
            func(ml+1,sl,er,ml,mr+1,ml);
            func(mr+1,ml+1,er,el,mr+1,ml+1);        

        }
    }
    else
    {
        if(l<=ml)   //左部分
        {
            h3++;
        //    cout<<"放L3"<<endl;
            a[mr][ml] = 3;
            a[mr][ml+1] = 3;
            a[mr+1][ml+1] = 3;
            //递归四次,
            func(sr,sl,mr,ml,mr,ml);
            func(sr,mr+1,mr,el,mr,ml+1);
            func(ml+1,sl,er,ml,r,l);
            func(mr+1,ml+1,er,el,mr+1,ml+1);        

        }
        else
        {
            h4++;
        //    cout<<"放L4"<<endl;
            a[mr][ml] = 4;
            a[mr][ml+1] = 4;
            a[mr+1][ml] = 4;
            //递归四次,
            func(sr,sl,mr,ml,mr,ml);
            func(sr,mr+1,mr,el,mr,ml+1);
            func(ml+1,sl,er,ml,mr+1,ml);
            func(mr+1,ml+1,er,el,r,l);        

        }
    }

   
}
int main()
{
    int n;
    int i,j,r,l;
    cin>>n;
    n = (int)pow(2,n);
    for(i=1;i<=n;i++)
    {
        for(j=1;j<=n;j++)
            a[i][j] = 0;
    }
    cin>>r>>l;
    cout<<"行数"<<n<<endl;
    a[r][l] = 5;
    func(1,1,n,n,r,l);
    cout<<h1<<' '<<h2<<' '<<h3<<' '<<h4<<endl;

    for(i=1;i<=n;i++)
    {
        for(j=1;j<=n;j++)
            cout<<a[i][j]<<' ';
        cout<<endl;
    }
   
   
    cout<<n<<endl;
    return 0;
}


哪错了 找不出来
搜索更多相关主题的帖子: include 正整数 
2013-03-18 17:07
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:3 
真的好难,都看不懂题目,不如把原网址粘贴出来?


[fly]存在即是合理[/fly]
2013-03-18 19:49
tompobing
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:260
专家分:809
注 册:2012-12-9
收藏
得分:3 
来看下
2013-03-18 21:48
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:3 
看代码长度就知道,一定是个很NB的题目。。。我就不不自量力了

PS:去看看提问的智慧吧

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-03-19 08:25
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:3 
这题目谈不上NB,L型骨牌覆盖是分治法的教学级问题。看楼主的代码就知道对分治法的理解还不到位,算法的应用不够熟练,可以说是在生搬硬套。这样的代码,计算范围小,n的值超过6便不能计算,算法效率太低O(2∧(2*n)),对于n=30的结果,即使有那么大的内存用也别想能活着看到结果。

事实上这个问题只需要O(n)的时间复杂度,空间复杂度也是S(n),即使n等于几万也就几个毫秒的事,需要的空间几十K足矣。代码也用不着这么长。

10分,就说这么多吧,手机上戳字是件很不爽的事

重剑无锋,大巧不工
2013-03-19 15:00
快速回复:真的好难
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024919 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved