素数环问题

素数环是一个计算机程序问题,指的是将从1到n这n个整数围成一个圆环,
若其中任意2个相邻的数字相加,结果均为素数,那么这个环就成为素数环。
问题描述:将从1到n这n个整数围成一个圆环,若其中任意2个相邻的数字相加,结果均为素数,那么这个环就成为素数环。n=20时,下面的序列就是一个素数环:
1 2 3 4 7 6 5 8 9 10 13 16 15 14 17 20 11 12 19 18
英文名:Prime Ring Problem
算法思想:采用回溯法实现,遍历全部可能的情况,最终答案:有6309300中可能情况。

算法优化:由于相邻两个数为素数,则必然一奇一偶,所以要是n=奇数时必然无解
如下代码:


image.png
package me.ice.practice;

/**
 * time     5/24/2017
 * auther   ice
 * description:
 * <p>
 * 素数环是一个计算机程序问题,指的是将从1到n这n个整数围成一个圆环,
 * 若其中任意2个相邻的数字相加,结果均为素数,那么这个环就成为素数环。
 * <p>
 * 问题描述:将从1到n这n个整数围成一个圆环,若其中任意2个相邻的数字相加,结果均为素数,那么这个环就成为素数环。
 * n=20时,下面的序列就是一个素数环:
 * 1 2 3 4 7 6 5 8 9 10 13 16 15 14 17 20 11 12 19 18
 * 英文名:Prime Ring Problem
 * <p>
 * <p>
 * 算法思想:采用回溯法实现,遍历全部可能的情况
 */
public class PrimeCircleProblem {

    public static int count = 0;

    public static void main(String[] args) {
        int[] a = new int[21];
        long start = System.currentTimeMillis();
        boolean ringProblem = getPrimeRingProblem(a);
        if (ringProblem) {
            long end = System.currentTimeMillis();
            System.out.println("总共用时:" + (end - start));
            System.out.println("总有" + count + "种可能");
        } else {
            System.out.println("此问题无解!");
        }

    }


    public static boolean getPrimeRingProblem(int a[]) {
        int k = 1;
        int n = a.length;
        a[0] = 1;

        //如果是奇数,则无解
        if ((n & 1) == 1) {
            return false;
        }

        while (k >= 1) {
            a[k]++;

            while (a[k] <= n) {
                if (check(a, k)) {
                    break;
                } else {
                    a[k]++;
                }
            }

            if (a[k] <= n && k == n - 1) {
                printArray(a);
            }

            if (a[1] == n + 1) {
                return true;
            }


            if (a[k] <= n && k < n - 1) {
                k += 1;
            } else {
                a[k--] = 0;
            }
        }

        return false;
    }

    private static boolean check(int[] a, int i) {

        if (!isPrime(a[i] + a[i - 1])) {
            return false;
        }

        //判断是否前面是否有跟它相同的值
        for (int j = 0; j < i; j++) {
            if (a[j] == a[i]) {
                return false;
            }
        }

        if (i == a.length - 1) {
            return isPrime(a[0] + a[a.length - 1]);
        }

        return true;
    }

    public static boolean isPrime(int n) {

        //如果是负数当做正数来进行处理
        if (n < 0) {
            n = -n;
        }

        if (n == 1 || n == 0) {
            return false;
        }
        int r = (int) Math.sqrt(n);
        for (int i = 2; i <= r; i++) {
            if (n % i == 0) {
                return false;
            }
        }
        return true;
    }


    private static void printArray(int[] array) {
        count++;
        //System.out.print("第" + (count++) + "个: ");
        //for (int i = 0; i < array.length; i++) {
        //    if (i < array.length - 1) {
        //        System.out.print(array[i] + "、");
        //    } else {
        //        System.out.println(array[i]);
        //    }
        //}
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容

  • 1)这本书为什么值得看: Python语言描述,如果学的Python用这本书学数据结构更合适 2016年出版,内容...
    孙怀阔阅读 12,463评论 0 15
  • 转载自Matrix大牛一个数是素数(也叫质数),当且仅当它的约数只有两个——1和它本身。规定这两个约数不能相同,因...
    Gitfan阅读 2,066评论 0 1
  • 良渚(环太湖/主要在浙江) 良渚(-3300-2300BC) 国家标志:强制性的公共权力(合法使用武力的权力)、城...
    上下_求索阅读 471评论 0 0
  • 今年的春节实在和以往太不一样了。每年我都会提前准备好充足的物料和资料,开着我家的大白,然后带着我的宝贝们回老家过年...
    卷卷开心阅读 247评论 0 1
  • 今夜关注诗歌关注了你 边疆的秋风起兮 吹来淡淡的忧伤 谈谈的凉意 咋凉还闷时节最...
    天生厚客阅读 121评论 0 3