常用演算法(C#): 歌德巴哈猜想的演算法

來源:互聯網
上載者:User

歌德巴哈猜想:任何一個大於6的偶數都可以寫為兩個素數之和

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

namespace ExGoldbachConjecture
{
    class GoldbachConjecture
    {
        public bool IsPrimeNumber(int n)
        {
            bool b = true;
            if (n == 1 || n == 2)
                b = true;
            else
            {
                int sqr = Convert.ToInt32(Math.Sqrt(n));
                for (int i = sqr; i >= 2; i--)
                {
                    if (n % i == 0)
                    {
                        b = false;
                    }
                }
            }
            return b;
        }
        public bool goldbachConjecture(int n)
        {
            bool b = false;
            if (n % 2 == 0 && n > 6)
            {
                for (int i = 1; i <= n / 2; i++)
                {
                    bool b1 = IsPrimeNumber(i);//判斷i是否為素數
                    bool b2 = IsPrimeNumber(n - i);//判斷n-i是否為素數
                    if (b1 & b2)
                    {
                        Console.WriteLine("{0}={1}+{2}",n,i,n-i);
                        b = true;
                    }
                }
            }
            return b;
        }

        static void Main(string[] args)
        {
            Console.WriteLine("輸入一個大於6的偶數");
            int n = Convert.ToInt32(Console .ReadLine ());
            GoldbachConjecture g=new GoldbachConjecture ();
            bool b = g.goldbachConjecture(n);
            if (b)
            {
                Console.WriteLine("{0}能寫成兩個素數的和。", n);
            }
            else
            {
                Console.WriteLine("猜想錯誤。");
            }
        }
    }
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.