李虹霖

 

回溯算法之素数环

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace SeqListSort
{
    /// <summary>
    /// <ather>
    /// lihonglin
    /// </ather>
    /// <content>
    /// 把从1到20这20个数摆成一个环,要求相邻的两个数的和是一个素数。
    ///分析:用回溯算法,考察所有可能的排列
    /// </content>
    /// </summary>
    class PrimeFor
    {
        static int n = 14;
        static int[] a = new int[20];//a数组存放素数环

        public static void InitPrimeFor()
        {
            for (int i = 0; i < 20; ++i )
            {
                a[i] = i + 1;
            }
        }

        public static void Swap( int i,  int j)
        {
            a[i] = a[i] + a[j] - (a[j] = a[i]);
        }

        static void PrintResult()
        {
            for (int i = 0; i < n; ++i)
            {
                Console.Write("{0,-4}" , a[i]);
            }
            Console.WriteLine();
        }

        static bool IsOK(int num)
        {
            for ( int i = 2; i <= (int)Math.Sqrt(num); ++i )
            {
                if (0 == num % i)
                {
                    return false;
                }
            }
            return true;
        }

        public static void Search(int k)
        {
            int i = 0;
            if ( k > n - 1 )//判断结束条件
            {
                if ( IsOK(a[0] + a[n - 1]) )
                    PrintResult();
                return;
            }
            else
            {
                for (i = k; i < n; ++i )
                {
                    Swap(k, i);
                    if(IsOK(a[k - 1] + a[k]))
                    {
                        Search(k + 1);//继续探索
                    }
                    //回溯
                    Swap(k, i);
                }
               
            }
        }
    }
}

 

posted on 2015-03-02 01:13  lol霖  阅读(650)  评论(0编辑  收藏  举报

导航