吸血鬼数字求解

java编程思想第四章练习10


吸血鬼数字是指位数为偶数的数字,可以由一对数字相乘而得到,而这对数字各包含乘积的一半位数的数字,其中从最初的数字中选取的数字可以任意排序。以两个0结尾的数字是不允许的,例如,下列数字都是吸血鬼数字:


1260=21*60

1827=21*87

2187=27*81


下面代码结合了书本给出的方法和网上的一种比较方法,比较方便,求四位吸血鬼数字,比较次数为590次


import java.util.*;

public class TestDemo {

	public static void main(String[] args) {
		int count = 0;		//计数器,用来记录比较次数
		int[] begin = new int[4];
		int[] target = new int[4];
		ArrayList<Integer> result = new ArrayList<>();		//用arraylist排除相同的结果
		for (int num1 = 10; num1 <= 99; num1++) {			//只有两位数才有可能成为吸血鬼数字
			for (int num2 = 10; num2 < 99; num2++) {
				if ((num1 * num2) % 9 != (num1 + num2) % 9) {	//书本给出的定理,筛选数字
					continue;
				}
				count ++;
				int temp = num1 * num2;
				begin[0] = num1 / 10;			//取出各位上的数字
				begin[1] = num1 % 10;
				begin[2] = num2 / 10;
				begin[3] = num2 % 10;
				target[0] = temp / 1000;
				target[1] = (temp % 1000) / 100;
				target[2] = (temp % 1000 % 100) / 10;
				target[3] = temp % 1000 % 100 % 10;
				Arrays.sort(begin);
				Arrays.sort(target);
				if (Arrays.equals(begin, target)) {		//排序比较
					if(!result.contains(temp)){			//排除相同的结果
						result.add(temp);
						System.out.println(num1 + "*" + num2 + "=" + temp);
					}
				}
				
			}
			
		}
		System.out.println(count);
		
	}

}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个Java程序,可以找出所有4位数的吸血鬼数字: ```java public class VampireNumbers { public static void main(String[] args) { for (int i = 1000; i < 10000; i++) { int a = i / 1000; int b = (i / 100) % 10; int c = (i / 10) % 10; int d = i % 10; if (checkVampireNumber(a, b, c, d, a, b, c, d)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, a, b, d, c)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, a, c, b, d)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, a, c, d, b)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, a, d, b, c)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, a, d, c, b)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, b, a, c, d)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, b, a, d, c)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, b, c, a, d)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, b, c, d, a)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, b, d, a, c)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, b, d, c, a)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, c, a, b, d)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, c, a, d, b)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, c, b, a, d)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, c, b, d, a)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, c, d, a, b)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, c, d, b, a)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, d, a, b, c)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, d, a, c, b)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, d, b, a, c)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, d, b, c, a)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, d, c, a, b)) { System.out.println(i); } if (checkVampireNumber(a, b, c, d, d, c, b, a)) { System.out.println(i); } } } public static boolean checkVampireNumber(int a, int b, int c, int d, int w, int x, int y, int z) { int num1 = 10 * a + b; int num2 = 10 * c + d; int product = num1 * num2; int firstHalf = 10 * w + x; int secondHalf = 10 * y + z; return product == firstHalf * secondHalf && product % 100 != 0; } } ``` 该程序通过枚举所有可能的数字组合,并检查它们是否满足吸血鬼数字的定义来找出所有4位数的吸血鬼数字

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值