吸血鬼数字

吸血鬼数字是指位数为偶数的数字,可以由一对数字相乘而得到,而这对数字各包含乘积的一半位数的数字,其中从最初的数字中选取的数字可以任意排序。
code完整版Java版本

package com.code4;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * Created by zhou on 17-12-2.
 *
 * @see 吸血鬼数字
 */
public class Ex10 {
    private static final int num = 9999;

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

    public static void isit() {
        int n;
        String str, a, b;
        for (int i = 0; i < 100; i++) {
            for (int j = 0; j < 100; j++) {
                n = i * j;
                str = n + "";
                a = i + "";
                b = j + "";
                if (a.length() > 1 & b.length() > 1 & str.length() == 4) {//必须为2位数
                    StringBuilder builder = new StringBuilder();
                    builder.append(str.toCharArray()[2]);
                    builder.append(str.toCharArray()[3]);
                    if (!builder.toString().equals("00")) {//后两位不能以0结尾
                        if (n <= num) {
                            List<String> stringList = isList(str.toCharArray());//转换为集合
                            String x1 = a.toCharArray()[0] + "";//取数字i的第1位
                            String x2 = a.toCharArray()[1] + "";//取数字i的第2位
                            String y1 = b.toCharArray()[0] + "";//取数字j的第1位
                            String y2 = b.toCharArray()[1] + "";//取数字j的第2位
                            if (stringList.contains(x1) && stringList.contains(x2)) {//i的每一位都是集合中到元素
                                if (stringList.contains(y1) && stringList.contains(y2)) {//j到每一位都是集合中到元素
                                    /*最后处理每个元素都只能用一次*/
                                    if (!x1.equals(x2) && !x1.equals(y1) && !x1.equals(y2)) {
                                        if (!x2.equals(y1) && !x2.equals(y2) && !y1.equals(y2)) {
                                            System.out.println(i + " * " + j + " = " + n);
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }

    public static List<String> isList(char... chars) {
        List<String> list = new ArrayList<String>();
        for (int i = 0; i < chars.length; i++) {
            list.add("" + chars[i]);
        }
        return list;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 吸血鬼数字指,位数为偶数,可以由一对数字相乘得到,且这对数字各包含乘积的一半位数的数字。其中,从最初的数字中选取的...
    Jocelyn_b0e1阅读 977评论 0 0
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,776评论 0 33
  • 简单了解吸血鬼数 今天看文档,突然看到一个奇怪的名字——“吸血鬼数”。大概查了一下,这种数字有正常的吸血鬼数,伪吸...
    Alisallon阅读 1,189评论 0 1
  • 故障: 在行驶中熄火,在打不着,推路边等一会在打火就着了,上周出现两次,刚才来时路上熄火两次, 诊断: 保养完,用...
    宏宇_8a57阅读 470评论 0 1
  • 我们住在同一个城市,我们只有一墙之隔。我们曾出现在彼此的童年中,我们有着相同的喜好和兴趣,但,那又如何,我们还是经...
    蘑小菇_83375阅读 465评论 0 2