zoukankan      html  css  js  c++  java
  • AOJ.859 地毯填补问题 (递归与分治)

    AOJ.859 地毯填补问题 (递归与分治)

    题意分析

    学习分治思想,第一次接触,

    代码总览

    #include <iostream>
    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    #include <sstream>
    #include <set>
    #include <map>
    #include <queue>
    #include <stack>
    #include <cmath>
    #define INF 0x3f3f3f3f
    #define nmax 200
    #define MEM(x) memset(x,0,sizeof(x))
    using namespace std;
    int k;
    void work(int x,int y,int l,int temp,int fx,int fy)
    {
         if(temp==1){
            if(fx==x && fy==y){
                 printf("%d %d %d
    ",fx+1,fy+1,1);
                 return;
            }
            if(fx==x && fy!=y){
                if(fx+1==7 && fy-1==2)
                    fx=6;
                    printf("%d %d %d
    ",fx+1,fy-1,2);
                    return;
            }
            if(fx!=x && fy==y){
                printf("%d %d %d
    ",fx-1,fy+1,3);
                return;
            }
            printf("%d %d %d
    ",fx-1,fy-1,4);return;
         }
         int nx,ny,nl=l/2;
         nx=x+nl;
         ny=y+nl;
         if(fx>=x && fx<nx && fy>=y && fy<ny){
             printf("%d %d %d
    ",nx,ny,1);
             work(x,y,nl,temp-1,fx,fy);
             work(x,ny,nl,temp-1,nx-1,ny);
             work(nx,y,nl,temp-1,nx,ny-1);
             work(nx,ny,nl,temp-1,nx,ny);
             return;
         }
        if(fx>=x && fx<nx && fy>=ny){
             printf("%d %d %d
    ",nx,ny-1,2);
             work(x,y,nl,temp-1,nx-1,ny-1);
             work(x,ny,nl,temp-1,fx,fy);
             work(nx,y,nl,temp-1,nx,ny-1);
             work(nx,ny,nl,temp-1,nx,ny);
             return;
        }
        if(fx>=nx && fy>=y && fy<ny){
             printf("%d %d %d
    ",nx-1,ny,3);
             work(x,y,nl,temp-1,nx-1,ny-1);
             work(x,ny,nl,temp-1,nx-1,ny);
             work(nx,y,nl,temp-1,fx,fy);
             work(nx,ny,nl,temp-1,nx,ny);
             return;
        }
        printf("%d %d %d
    ",nx-1,ny-1,4);
        work(x,y,nl,temp-1,nx-1,ny-1);
        work(x,ny,nl,temp-1,nx-1,ny);
        work(nx,y,nl,temp-1,nx,ny-1);
        work(nx,ny,nl,temp-1,fx,fy);
        return;
    }
    int main ()
    {
         //freopen("in.txt","r",stdin);
         int x,y,len =1,i;
         scanf("%d",&k);
         scanf("%d %d",&x,&y);
         i = k;
         while (i--) len*=2;
         work(1,1,len,k,x,y);
    }
    
  • 相关阅读:
    Prometheus-node-exporter
    Prometheus基础
    普通函数与回调函数的区别
    HTML转义字符大全
    使用 Chrome DevTools 模拟缓慢的 3G 网络速度
    Chrome 浏览器如何修改 User-Agent
    服务器上的 Git
    Mac配置go环境变量
    Linux和Mac环境变量设置
    Cloudflare DNS设置中子域委派不成功的问题
  • 原文地址:https://www.cnblogs.com/pengwill/p/7367103.html
Copyright © 2011-2022 走看看