素数环问题

作者: 疯狂的冰块 | 来源:发表于2017-05-24 17:30 被阅读33次

素数环是一个计算机程序问题,指的是将从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]);
        //    }
        //}
    }
}

相关文章

  • 素数环问题

    素数环是一个计算机程序问题,指的是将从1到n这n个整数围成一个圆环,若其中任意2个相邻的数字相加,结果均为素数,那...

  • DFS(素数环)

    Prime Ring Problem Problem Description A ring is compose ...

  • 素数问题

    1.辗转相除法 gcd函数用于求两数的最大公约数,该函数递归的返回a,b中较小的数和他们相除之后的余数。直到两数除...

  • Java常见算法整理

    兔子问题(斐波那契数列规律) 台阶问题 (兔子问题变种,递归规律) 素数问题(判断素数、质数方式) 水仙花数问题(...

  • 7-4 素数环

    https://vjudge.net/problem/UVA-524 就是一个简单的回溯法 注意1是固定的 所以传...

  • 回溯法求解素数环

  • 质数问题

    问题 请判断101-200之间有多少个素数,且输出所有的素数。 问题分析 素数(质数)在大于1的自然数中,除了1和...

  • 枚举算法之最大素数

    问题:求解(0,N)中的最大素数

  • 素数筛法——1. 素数判定

    素数判定问题 题目描述 给定一个数n,要求判断其是否为素数(0,1,负数都是非素数)。 输入描述: 测试数据有多组...

  • C/C++算法刷题系列(2)

    在我们刷题时经常会遇到素数问题。素数:能被1和本身整除的数,即为素数;例如: 2,3,5,7,11,13均符合这样...

网友评论

    本文标题:素数环问题

    本文链接:https://www.haomeiwen.com/subject/ttyoxxtx.html