首页 > 其他分享 >蓝桥杯2015年第十三届省赛真题-三羊献瑞

蓝桥杯2015年第十三届省赛真题-三羊献瑞

时间:2024-03-31 15:32:05浏览次数:21  
标签:arr 递归 真题 int dfs 蓝桥 static 献瑞 public

一、题目

观察下面的加法算式:

      祥 瑞 生 辉
  +  三 羊 献 瑞
----------------------
 三 羊 生 瑞 气

(如果有对齐问题,可以参看【图1】)

其中,相同的汉字代表相同的数字,不同的汉字代表不同的数字。

请你填写“三羊献瑞”所代表的4位数字(答案唯一),不要填写任何多余内容。

图1

二、分析

 问的是三羊献瑞所代表的4位数字,那么我们可以看见这里总共有8个汉字,那么每个汉字都有可能是0~9这10个数字,但是祥和三不能为0,所以我们可以以深度优先算法进行全排列,找出符合条件的数字。


这里先给出一个深度优先算法进行全排列的小例题:

我们设数字是 {1 2 3 4 },那么递归求全排列

 要求 全排列 我们的总体思想是:先将数字存到数组里面,将当前的元素与后面的元素进行交换,然后递归地处理剩下的元素,直到递归到最后一个元素,输出当前的序列,我们再回溯到上一层,继续进行递归来搜索其他的序列。

        代码:

package dfs进行全排列;

import java.util.Arrays;

public class A {

	public static void main(String[] args) {
		dfs(0, arr.length-1);
		
	}
	
	public static int[] arr = {1,2,3,4};
	
	public static void dfs(int start, int end) {
		//退出的条件
		if(start == end) {
			System.out.println(Arrays.toString(arr));
			return;
		}
		
		//递归处理全排列
		for(int i = start; i <= end; i++) {
			swap(arr, start, i);//将当前的元素与后面的元素进行交换
			dfs(start+1, end);//递归地处理剩下的元素,直到递归到最后一个元素
			swap(arr, start, i);//回溯到上一层继续进行递归
		}
	}
	
	public static void swap(int[] arr, int i, int j) {
		int temp = arr[i];
		arr[i] = arr[j];
		arr[j] = temp;
	}
}

        结果: 

[1, 2, 3, 4]
[1, 2, 4, 3]
[1, 3, 2, 4]
[1, 3, 4, 2]
[1, 4, 3, 2]
[1, 4, 2, 3]
[2, 1, 3, 4]
[2, 1, 4, 3]
[2, 3, 1, 4]
[2, 3, 4, 1]
[2, 4, 3, 1]
[2, 4, 1, 3]
[3, 2, 1, 4]
[3, 2, 4, 1]
[3, 1, 2, 4]
[3, 1, 4, 2]
[3, 4, 1, 2]
[3, 4, 2, 1]
[4, 2, 3, 1]
[4, 2, 1, 3]
[4, 3, 2, 1]
[4, 3, 1, 2]
[4, 1, 3, 2]
[4, 1, 2, 3]

Arrays.ToString(数组名);数组转换为字符串,用之前记得要导包import java.util.Arrays;

  本题的代码

package lan2015;

public class C三羊献瑞 {

	public static void main(String[] args) {
		dfs(0);
	}
	
	public static int[] arr = {0,1,2,3,4,5,6,7,8,9};
	
	public static void dfs(int m) {
		if(m >= 9) {
			int a = arr[0]*1000+ arr[1]*100 + arr[2]*10 + arr[3];
			int b = arr[4]*1000+ arr[5]*100 + arr[6]*10 + arr[1];
			int c = arr[4]*10000+ arr[5]*1000+ arr[2]*100 + arr[1]*10 + arr[7];
			if(arr[0]==0 || arr[4]==0) return;
			if(a+b == c) {
				System.out.println(arr[4]+" "+arr[5]+" "+arr[6]+" "+arr[1]);
			}
			return;
		}
		
		//递归搜索
		for(int i = m; i <= 9; i++) {
			swap(m, i);
			dfs(m+1);
			swap(m, i);
		}
	}
	
	public static void swap(int i , int j) {
		int t =arr[i];
		arr[i] = arr[j];
		arr[j] = t;
	}
}

执行结果:

1 0 8 5
1 0 8 5

标签:arr,递归,真题,int,dfs,蓝桥,static,献瑞,public
From: https://blog.csdn.net/2301_76876837/article/details/137170454

相关文章

  • 蓝桥杯2018年第十三届省赛真题-复数幂
    一、题目复数幂设i为虚数单位。对于任意正整数n,(2+3i)^n的实部和虚部都是整数。求(2+3i)^123456等于多少?即(2+3i)的123456次幂,这个数字很大,要求精确表示。答案写成"实部±虚部i"的形式,实部和虚部都是整数(不能用科学计数法表示),中间任何地方都不加空格,实部为正时前面......
  • 蓝桥杯2016年第十三届省赛真题-生日蜡烛
    一、题目生日蜡烛.某君从某年开始每年都举办一次生日party,并且每次都要吹熄与年龄相同根数的蜡烛。现在算起来,他一共吹熄了236根蜡烛。请问,他从多少岁开始过生日party的?请填写他开始过生日party的年龄数。注意:你提交的应该是一个整数,不要填写任何多余的内容或说明性文字......
  • 蓝桥杯2021年第十三届省赛真题-直线
    一、题目【问题描述】    在平面直角坐标系中,两点可以确定一条直线。如果有多点在一条直线上,那么这些点中任意两点确定的直线是同一条。    给定平面上2×3个整点{(x,y)|0≤x<2,0≤y<3,x∈Z,y∈Z},即横坐标是0到1(包含0和1)之......
  • 蓝桥杯2014年第十三届省赛真题-猜字母
    一、题目猜字母  把abcd...s共19个字母组成的序列重复拼接106次,得到长度为2014的串。  接下来删除第1个字母(即开头的字母a),以及第3个,第5个等所有奇数位置的字母。  得到的新串再进行删除奇数位置字母的动作。如此下去,最后只剩下一个字母,请写出该字母。答案是......
  • 蓝桥杯2020年第十三届省赛真题-合并检查
    一、题目合并检测新冠疫情由新冠病毒引起,最近在A国蔓延,为了尽快控制疫情,A国准备给大量民众进病毒核酸检测。然而,用于检测的试剂盒紧缺。为了解决这一困难,科学家想了一个办法:合并检测。即将从多个人(k个)采集的标本放到同一个试剂盒中进行检测。如果结果为阴性,则说明这k......
  • 蓝桥杯2019年第十三届省赛真题-数列求值
    一、题目数列求值【问题描述】给定数列1,1,1,3,5,9,17,…,从第4项开始,每项都是前3项的和。求第20190324项的最后4位数字。【答案提交】这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个4位整数(提示:答案的千位不为0),在提交答案时只填......
  • java计算机毕业设计(附源码)阳光学院蓝桥杯名师工作室(ssm+mysql+maven+LW文档)
    本系统(程序+源码)带文档lw万字以上  文末可领取本课题的JAVA源码参考系统程序文件列表系统的选题背景和意义选题背景:阳光学院蓝桥杯名师工作室的成立,源自于当前信息技术迅猛发展的时代背景和对高素质计算机人才的迫切需求。在全球化和数字化浪潮推动下,编程能力、算法设计......
  • CCF-CSP真题《202309-3 梯度求解》题解
    题目string转longlong忘记处理负数卡了半天,服了#include<iostream>#include<cstdio>#include<cstring>#include<sstream>typedeflonglongll;usingnamespacestd;intn,m,temp;lla[302];stringf,x,b;llmod=1e9+7;structnode{ stringcon; n......
  • 【2024年5月备考新增】《软考真题分章练习(含答案解析) - 14 组织级项目管理(高项)》
    1题目1、办公软件开发公司A非常重视软件过程管理,按照CMMI(能力成熟度模型)逐步进行过程改进,刚刚实现了组织级过程性能、定量项目管理,按照CMMI(能力成熟度模型),A公司达到了()级别。A.CMMI2B.CMMI3C.CMMI4D.CMMI52、CMMI的连续式表示法与阶段式表示法分别表示:()。A.项......
  • 七段码(蓝桥杯)
    文章目录七段码题目描述答案:80分析编程求解:有多种方法方法一:状态压缩+枚举+构图(以二极管为顶点)+DFS判断连通代码方法二:bfs七段码题目描述小蓝要用七段码数码管来表示一种特殊的文字。上图给出了七段码数码管的一个图示,数码管中一共有7段可以发光的二极管,分别......