zoukankan      html  css  js  c++  java
  • 002:马走日

    002:马走日

    题目链接:http://cxsjsxmooc.openjudge.cn/2017t2summerfinal/002/

    总时间限制:
    1000ms
    内存限制:
    1024kB
    描述

    马在中国象棋以日字形规则移动。

    请编写一段程序,给定n*m大小的棋盘,以及马的初始位置(x,y),要求不能重复经过棋盘上的同一个点,计算马可以有多少途径遍历棋盘上的所有点。

    输入
    第一行为整数T(T < 10),表示测试数据组数。
    每一组测试数据包含一行,为四个整数,分别为棋盘的大小以及初始位置坐标n,m,x,y。(0<=x<=n-1,0<=y<=m-1, m < 10, n < 10)
    输出
    每组测试数据包含一行,为一个整数,表示马能遍历棋盘的途径总数,0为无法遍历一次。
    样例输入
    1
    5 4 0 0
    样例输出
    32

    /*
    应该是数据有点弱
    本来想先交一下看看不优化能跑多少样例
    谁知道直接过了....... 
    
    */ 
    #include <cstdio>
    #include <cstring>
    #define maxn 10
    //马向八个方向走的偏移量 
    int dirx[] = {-2 , -2 , -1 , -1 , 1 , 1, 2 , 2 } ; 
    int diry[] = {-1 , 1 , -2 , 2 , -2 , 2 , -1 , 1 } ; 
    int visit[maxn][maxn] ; 
    int n , m ; 
    int times = 0 ; 
    
    bool check(int x , int y){
        if(x>=0&&x<n&&y>=0&&y<m)
        return true ; 
        return false ; 
    }
    
    void DFS(int x , int y , int step){
        if(step == n*m){
            times ++ ;
            return; 
        }
        int turnx , turny ; 
        for(int i=0 ; i<8 ; i++){
            turnx = x + dirx[i] ; 
            turny = y + diry[i] ; 
            if(check(turnx , turny)&&!visit[turnx][turny]){
                visit[turnx][turny] = 1 ; 
                DFS(turnx , turny , step+1) ; 
                visit[turnx][turny] = 0 ; // 回溯时 撤销标记  为搜寻下一种可能性 做准备 
            }
        }
        return;
    }
    
    int main(){
        int t , x , y ; 
        scanf("%d" , &t) ; 
        while(t--){
            times = 0 ; 
            scanf("%d%d%d%d" , &n , &m , &x , &y ) ; 
            memset(visit , 0 , sizeof(visit)) ; 
            visit[x][y] = 1 ; 
            DFS(x , y , 1 ) ; 
            printf("%d
    " , times) ; 
        }
        return 0 ; 
    }
  • 相关阅读:
    求一个二维数组的最大子矩阵(王伟光,曹锦锋)
    第二个冲刺周期第2天
    软件——第二个冲刺周期
    我的软件创意——历史上的今天
    我的ideas之网络安全——基于NABC模型
    电梯调度 最终版
    敏捷软件开发方法——scrum
    求一个二维数组中 子数组和的最大值
    电梯调度算法(二)
    结对项目开发-电梯调度(大体设计思路)
  • 原文地址:https://www.cnblogs.com/yi-ye-zhi-qiu/p/7583845.html
Copyright © 2011-2022 走看看