2014年第五届蓝桥杯省赛试题及详解(Java本科A组)第三题 神奇的算式

神奇算式

由4个不同的数字,组成的一个乘法算式,它们的乘积仍然由这4个数字组成。

比如: 

210 x 6 = 1260
8 x 473 = 3784
27 x 81 = 2187

都符合要求。

如果满足乘法交换律的算式算作同一种情况,那么,包含上边已列出的3种情况,
一共有多少种满足要求的算式。

请填写该数字,通过浏览器提交答案,不要填写多余内容(例如:列出所有算式)。

答案:12,,我的思路是遍历所有的四位数,再判断其是否有重复字符,反之则将其记录int数组中,进行全排列且运算是否有满足乘积与之相同。由于两者交换乘积值也满足就出现重复,所以最后的答案需ans/2.

private static int num;
	private static int ans;
	static int[] ch= {0,0,0,0};
	public static void main(String[] args) {
		String s = "";
		for (int i = 1023; i < 10000; i++) {
			s = i + "";
			if (isUniqueChars2(s)) {
				num=i;				
				f(0);
			}
		}
		System.out.println(ans/2);
	}

	private static void f(int pos) {
		int x=0;
		if(pos>=3) {
			for(int a=0;a<3;a++) {
				x=x*10+ch[a];
				int y=0;
				for(int b=a+1;b<4;b++) {
					y=y*10+ch[b];
				}
				if(x*y==num) {
					ans++;					
				}
			}
			return;
		}
		for (int i = pos; i < ch.length; i++) {//全排列
			int c = ch[pos];
			ch[pos] = ch[i];
			ch[i] = c;
			f(pos + 1);			
			c = ch[pos];
			ch[pos] = ch[i];
			ch[i] = c;
		}		
	}

	//判断四位数是否有重复字符和四位数转换为int[] 数组
	public static boolean isUniqueChars2(String str) {
		int[] b = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };//下标重0~9十个数
		char[] c = str.toCharArray();
		for (int i = 0; i < c.length; i++) {
			int num = c[i] - '0';
			ch[i]=num;//数字加入到数组
			if (b[num] == 1) {
				return false;
			}
			b[num] = 1;//只出现一次标记
		}
		return true;
	}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值