吸血鬼数字算法—Java

有关吸血鬼数字算法的问题我找了很多, 发现大概有三种思路,当然不是具体的实现, 如下:

1. "笨方法1:“

代码如下:

public class getBloodGostNumber
{
	public static void printBloodGostNumber()
	{
		int a, b, c, d;
		for (int i = 1001; i < 10000; i++)
		{
			a = i / 1000;
			b = i % 1000 / 100;
			c = i % 100 / 10;
			d = i % 10;

			if (i == (a * 10 + b) * (c * 10 + d))
			{
				System.out.println("" + i + " = " + (a * 10 + b) + " * " + (c * 10 + d));

			}

			else if (i == (a * 10 + b) * (d * 10 + c))
			{
				System.out.println("" + i + " = " + (a * 10 + b) + " * " + (d * 10 + c));

			}

			else if (i == (b * 10 + a) * (c * 10 + d))
			{
				System.out.println("" + i + " = " + (b * 10 + a) + " * " + (c * 10 + d));

			}

			else if (i == (b * 10 + a) * (d * 10 + c))
			{
				System.out.println("" + i + " = " + (b * 10 + a) + " * " + (d * 10 + c));

			}

			else if (i == (a * 10 + c) * (b * 10 + d))
			{
				System.out.println("" + i + " = " + (a * 10 + c) + " * " + (b * 10 + d));

			}

			else if (i == (a * 10 + c) * (d * 10 + b))
			{
				System.out.println("" + i + " = " + (a * 10 + c) + " * " + (d * 10 + b));

			}

			else if (i == (c * 10 + a) * (b * 10 + d))
			{
				System.out.println("" + i + " = " + (c * 10 + a) + " * " + (b * 10 + d));

			}

			else if (i == (c * 10 + a) * (d * 10 + b))
			{
				System.out.println("" + i + " = " + (c * 10 + a) + " * " + (d * 10 + b));

			}

			else if (i == (a * 10 + c) * (b * 10 + d))
			{
				System.out.println("" + i + " = " + (a * 10 + c) + " * " + (b * 10 + d));

			}

			else if (i == (a * 10 + d) * (b * 10 + c))
			{
				System.out.println("" + i + " = " + (a * 10 + d) + " * " + (b * 10 + c));

			}

			else if (i == (a * 10 + d) * (c * 10 + b))
			{
				System.out.println("" + i + " = " + (a * 10 + d) + " * " + (c * 10 + b));

			}

			else if (i == (d * 10 + a) * (b * 10 + c))
			{
				System.out.println("" + i + " = " + (d * 10 + a) + " * " + (b * 10 + c));

			}

			else if (i == (d * 10 + a) * (c * 10 + b))
			{
				System.out.println("" + i + " = " + (d * 10 + a) + " * " + (c * 10 + b));

			}
		}
	}

	public static void main(String[] args)
	{
		printBloodGostNumber();
	}
}

这里用的的是穷举法, 比较次数很多。。。。。


2.”笨方法2“

这次可以带过来写,代码如下:

import java.util.Arrays;

public class getBloodGostNumberAno
{
	public static void printBloodGostNumber()
	{
		int ret;
		int[] a = new int[4];
		int[] b = new int[4];
		for (int i = 10; i < 100; i++)
		{
			for (int j = 10; j < 100; j++)
			{
				ret = i * j;
				if (ret > 9999)
					continue;
				a[0] = ret / 1000;
				a[1] = ret % 1000 / 100;
				a[2] = ret % 100 / 10;
				a[3] = ret % 10;

				b[0] = i / 10;
				b[1] = i % 10;
				b[2] = j / 10;
				b[3] = j % 10;

				if (b[1] == 0 && b[3] == 0)
					continue;

				Arrays.sort(a);
				Arrays.sort(b);

				//System.out.println(Arrays.equals(a, b));

				if (Arrays.equals(a, b))
				{
					System.out.println("" + ret + " = " + i + " * " + j);
				}
			}
		}
	}

	public static void main(String[] args)
	{
		printBloodGostNumber();
	}
}
当然,具体实现时还可以用容器之类的。。。

3.我目前已知的最好的方法

代码如下:

import java.util.Arrays;

public class getBloodGostNumberAno2
{
	public static void printBloodGostNumber()
	{
		int ret;
		int from, to;
		int count = 0;
		int[] a = new int[4];
		int[] b = new int[4];
		for (int i = 10; i < 100; i++)
		{
			from = Math.max(1000 / i, i + 1);
			to = Math.min(9999 / i, 99);
			for (int j = from; j <= to; j++)
			{
				ret = i * j;

				if (ret % 100 == 0 || (ret -i - j) % 9 != 0) {
					continue;
				}
		
				a[0] = ret / 1000;
				a[1] = ret % 1000 / 100;
				a[2] = ret % 100 / 10;
				a[3] = ret % 10;

				b[0] = i / 10;
				b[1] = i % 10;
				b[2] = j / 10;
				b[3] = j % 10;

				count++;
				Arrays.sort(a);
				Arrays.sort(b);

				//System.out.println(Arrays.equals(a, b));

				if (Arrays.equals(a, b))
				{
					System.out.println("" + ret + " = " + i + " * " + j);
				}
			}
		}
		System.out.println(count);
	}

	public static void main(String[] args)
	{
		printBloodGostNumber();
	}
}

这里的比较次数最少。。。可以参考:

点击打开链接

点击打开链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值