zoukankan      html  css  js  c++  java
  • 振兴中华

    欢迎访问我的新博客:http://www.milkcu.com/blog/

    原文地址:http://www.milkcu.com/blog/archives/1395367620.html

    引言

    这是2013年蓝桥杯软件大赛预赛A组(C/C++组)第3题,是个填空题,和深度优先搜索(DFS)有关,数路线和代码实现均较容易。

    题目描述

    标题: 振兴中华

        小明参加了学校的趣味运动会,其中的一个项目是:跳格子。
        地上画着一些格子,每个格子里写一个字,如下所示:(也可参见p1.jpg)

    从我做起振
    我做起振兴
    做起振兴中
    起振兴中华



        比赛时,先站在左上角的写着“从”字的格子里,可以横向或纵向跳到相邻的格子里,但不能跳到对角的格子或其它位置。一直要跳到“华”字结束。
        要求跳过的路线刚好构成“从我做起振兴中华”这句话。
        请你帮助小明算一算他一共有多少种可能的跳跃路线呢?

    答案是一个整数,请通过浏览器直接提交该数字。
    注意:不要提交解答过程,或其它辅助说明类的内容。

    分析

    由于数据规模比较小,可以不用编程实现,直接一条一条路线的数数。

    比较好的方法是从上往下、从右往左的数,这样前面数过的路线刚好可以应用到后面的数数中。

    1 = 1
    1 + 2 = 3
    3 + 3 = 6
    6 + 4 = 10
    10 + 5 = 15

    所有路线加起来即可得到答案。

    当然这题也可以使用深度优先实现,代码也很简单。

    把“从我做起振兴中华”8个字替换为0~7的8个数字。

    使用深度优先算法可以很方便的得出结果。

    代码实现

    #include <iostream>
    #include <cmath>
    #include <cstring>
    using namespace std;
    int map[4][5] = {{0, 1, 2, 3, 4},
                     {1, 2, 3, 4, 5},
                     {2, 3, 4, 5, 6},
    				 {3, 4, 5, 6, 7}};
    int cnt = 0;
    int vis[4][5];
    void dfs(int a, int b) {
    	//cout << "dfs  " << a << "  " << b << endl;
    	if(vis[a][b]) {
    		return;
    	}
    	if(a == 3 && b == 4) {
    		cnt++;
    		return;
    	}
    	vis[a][b] = 1;
    	for(int i = -1; i <= 1; i++) {
    		for(int j = -1; j <= 1; j++) {
    			if(i == j || abs(i) == abs(j)) {
    				continue;
    			}
    			int newa = a + i;
    			int newb = b + j;
    			if(newa < 0 || newa >= 4 || newb < 0 || newb >= 5) {
    				continue;
    			}
    			if(map[newa][newb] - map[a][b] == 1) {
    				dfs(newa, newb);
    			}
    		}
    	}
    	vis[a][b] = 0;
    }
    int main(void) {
    	memset(vis, 0, sizeof(vis));
    	dfs(0, 0);
    	cout << cnt << endl;
    	return 0;
    }

    答案

    35

    (全文完)

  • 相关阅读:
    vue.config.js的配置与注释
    Git Pages,使用gh-pages分支显示静态网站
    git subtree 公共仓库
    vue之计算属性
    前端模块化AMD和CMD
    jQuery实现表单全选反选,简洁,好用
    vue之点击切换样式
    vue之本地代理解决跨域问题
    ES6
    jQuery 总结
  • 原文地址:https://www.cnblogs.com/milkcu/p/3808867.html
Copyright © 2011-2022 走看看