美文网首页蓝桥杯
【蓝桥杯】第五届-6-六角填数

【蓝桥杯】第五届-6-六角填数

作者: JacobKong_Dev | 来源:发表于2016-03-17 15:08 被阅读818次

题目

如图【1.png】所示六角形中,填入1~12的数字。

1.png

使得每条直线上的数字之和都相同。

图中,已经替你填好了3个数字,请你计算星号位置所代表的数字是多少?

请通过浏览器提交答案,不要填写多余的内容。

答案

10

分析

这道题最方便、最快捷、最能想到的必须是暴利求解,把六角星从上到下,从左到右分别编号1~12,然后利用DFS(深度遍历搜索)递归,把所有的可能都试一遍,直到满足每条直线上和相等则可得到*的解。
代码里面有两个数组a[]vis[]。分别用来存放1~12个数和记录哪个数被使用过,已经使用过则记为 true否则记为false,所以初始的时候:

a[1] = 1;
vis[1] = true;

a[2] = 8;
vis[8] = true;

a[12] = 3;
vis[3] = true;

然后从x=1开始运行dfs(int x)函数,求解。

代码

public class Six {
    static int N = 14;
    static int[] a = new int[N];
    static boolean[] vis = new boolean[N];
    public static void main(String[] args) {
        a[1] = 1;
        vis[1] = true;
        
        a[2] = 8;
        vis[8] = true;
        
        a[12] = 3;
        vis[3] = true;
        
        dfs(1);
    }

    // a是最长数组,k是子数组的first index
    private static void dfs(int x){
        if(x==1||x==2||x==12){
            dfs(x+1);
            return;
        }
        
        if(x>12){
            int t[] = new int[6];
            t[0] = a[1] + a[3] + a[6] + a[8];
            t[1] = a[1] + a[4] + a[7] + a[11];
            t[2] = a[2] + a[3] + a[4] + a[5];
            t[3] = a[2] + a[6] + a[9] + a[12];
            t[4] = a[8] + a[9] + a[10] + a[11];
            t[5] = a[12] + a[10] + a[7] + a[5];
            
            for(int i = 1; i< t.length; i++){
                if (t[i]!=t[i-1]) return;
            }
            
            System.out.println("*="+a[6]);
            return;
        }
        
        for(int i = 1; i<13; i++){
            if(!vis[i]){
                vis[i]=true;
                a[x] = i;
                dfs(x+1);
                vis[i]=false;
            }
        }
    }
}

相关文章

  • 【蓝桥杯】第五届-6-六角填数

    题目 如图【1.png】所示六角形中,填入1~12的数字。 使得每条直线上的数字之和都相同。 图中,已经替你填好了...

  • 蓝桥杯-搜索暴力

    1、六角填数 运用stl 中的函数next_permutation(a,a+n)题意:7:六角填数如图【1.png...

  • [蓝桥杯2016初赛]方格填数

    题目描述 如下的10个格子,填入0~9的数字。要求:连续的两个数字不能相邻。(左右、上下、对角都算相邻)一共有多少...

  • [蓝桥杯2015决赛]方格填数

    题目描述 在2行5列的格子中填入1到10的数字。要求:相邻的格子中的数,右边的大于左边的,下边的大于上边的。如下图...

  • 蓝桥杯填方格-填数问题

    问题描述 方格填数 如下的10个格子 填入0~9的数字。要求:连续的两个数字不能相邻。(左右、上下、对角都算相邻)...

  • 蓝桥杯-排他平方数

    题目标题: 排它平方数 小明正看着 203879 这个数字发呆。原来,203879 * 203879 = 4156...

  • dfs_第七届蓝桥杯方格填数

    方格填数 填入0~9的数字。要求:连续的两个数字不能相邻。 (左右、上下、对角都算相邻) 一共有多少种可能的填数方...

  • 蓝桥杯:回文数--Python解法

    问题描述 1221是一个非常特殊的数,它从左边读和从右边读是一样的,编程求所有这样的四位十进制数。 输出格式 按从...

  • 优质题解:数字游戏

    原题链接:[蓝桥杯][历届试题]数字游戏 解题思路:【1】.首先是明确只能计算主角的数,如果计算了别人的数,那么时...

  • 蓝桥杯第五届B组预选

    第一题:啤酒和饮料(4' ) 1)穷举2)利用工具计算 答案:11考虑精度的话 *10 就可以了,得到两个答案,因...

网友评论

本文标题:【蓝桥杯】第五届-6-六角填数

本文链接:https://www.haomeiwen.com/subject/mckqlttx.html