Chinaunix首页 | 论坛 | 博客
  • 博客访问: 293310
  • 博文数量: 69
  • 博客积分: 2946
  • 博客等级: 少校
  • 技术积分: 800
  • 用 户 组: 普通用户
  • 注册时间: 2010-04-09 04:15
文章分类

全部博文(69)

文章存档

2013年(6)

2012年(16)

2011年(18)

2010年(29)

分类: C/C++

2010-04-22 02:47:10


这个题目参考了王晓东那本书的算法,其实利用分治法比较简单,不用太多的技巧。

#include<cstdlib>
#include<iostream>
#define max 1024
int array[max][max];
int au =1;
using namespace std ;
int inter(int n )
{
    if(n==1)
    return 2 ;
    else return 2*inter(n-1);
}
void chessboard(int tr , int ts , int m , int n , int size)
{

//tr是行号,ts是列号,m,n分别是缺陷的行列号,size是这个盘的规格大小

     if(size==1) return ;
     else size = size /2 ;
     int flag=au++ ;
          
     if(m<tr+size&&n<ts+size) //左上角
     chessboard(tr,ts,m,n,size) ;
     else
     {
          array[tr+size-1][ts+size-1]=flag ;
          chessboard(tr,ts,tr+size-1,ts+size-1,size);
     }
     
     if(m<tr+size&&n>=ts+size) //右上角
     chessboard(tr,ts+size,m,n,size);
     else
     {
          array[tr+size-1][ts+size]=flag ;
          chessboard(tr,ts+size,tr+size-1,ts+size,size);
     }
     
     if(m>=tr+size&&n<ts+size) //左下角
     chessboard(tr+size,ts,m,n,size);
     else
     {
          array[tr+size][ts+size-1]=flag ;
          chessboard(tr+size,ts,tr+size,ts+size-1,size);
     }
     if(m>=tr+size&&n>=ts+size)
     chessboard(tr+size,ts+size,m,n,size);
     else
     {
          array[tr+size][ts+size]=flag ;
          chessboard(tr+size,ts+size,tr+size,ts+size,size);
          }
}
int main()
{
    int number ;
    int i , j ;
    cin>>number ;
    cin>>i >>j ;
    int n = inter(number);
    chessboard(0,0,i-1,j-1,n);
    //array[i-1][j-1]=0;
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++)
         {
                    cout<<array[i][j];
                    if(j==n-1)
                    cout<<endl;
                    else cout<<" ";
         }
        system("pause");
    return 0 ;
}


Web Hosting
阅读(705) | 评论(0) | 转发(1) |
0

上一篇:xmu 1015.AntiCAPS

下一篇:xmu 1029

给主人留下些什么吧!~~