C#模擬程式驗證 生日悖論

来源:http://www.cnblogs.com/chx197/archive/2016/03/25/5320538.html
-Advertisement-
Play Games

生日悖論,指如果一個房間里有23個或23個以上的人,那麼至少有兩個人的生日相同的概率要大於50%,準確的說是50.7左右,這就意味著在一個典型的標準小學班級(30人)中,存在兩人生日相同的可能性更高。對於60或者更多的人,這種概率要大於99%。從引起邏輯矛盾的角度來說生日悖論並不是一種悖論,從這個數 ...


生日悖論,指如果一個房間里有23個或23個以上的人,那麼至少有兩個人的生日相同的概率要大於50%,準確的說是50.7左右,這就意味著在一個典型的標準小學班級(30人)中,存在兩人生日相同的可能性更高。對於60或者更多的人,這種概率要大於99%。從引起邏輯矛盾的角度來說生日悖論並不是一種悖論,從這個數學事實與一般直覺相抵觸的意義上,它才稱得上是一個悖論。大多數人會認為,23人中有2人生日相同的概率應該遠遠小於50%。

這個結果是可以有數學公式計算出來的,咱們不談公式,直接實踐,用程式來模擬生成一個房間,包含23個人,檢測有無生日重覆項。重覆多次,累計結果即可,一下是源碼(控制台程式)

using System;
using System.Threading;

namespace ConsoleApplication1
{
    class Program
    {
        //一個日期,一個隨機器,用來生成隨機生日
        private static DateTime dt = Convert.ToDateTime("12-31");
        private static Random ran = new Random();


        /// <summary>
        /// 房間數量
        /// </summary>
        private static int roomNumber = 0;
        /// <summary>
        /// 符合條件的房間數量
        /// </summary>
        private static int roomRight = 0;
        /// <summary>
        /// 嘗試次數
        /// </summary>
        private static int test = 0;

        static void Main(string[] args)
        {
            Console.WriteLine("請輸入執行次數,只能為整數");
            try
            {
                test = Convert.ToInt32(Console.ReadLine());
                Thread t1 = new Thread(new ThreadStart(start));
                t1.Start();
            }
            catch
            {
                Console.WriteLine("輸入有誤,請重新運行。");
            }
            Console.ReadLine();
        }
        /// <summary>
        /// 開始進行模擬測試
        /// </summary>
        private static void start()
        {
            for (int i = 0; i < test; i++)
            {
                DateTime[] dtRoom = creatRoom();
                if (checkBirsday(dtRoom) == true)
                    roomRight++;
                Console.WriteLine("剩餘:"+(test - i).ToString());
            }
            float probability =  Convert.ToSingle(roomRight) / Convert.ToSingle(roomNumber);
            Console.WriteLine(String.Format("共 {0} 間房間,符合條件的有 {1} 間,概率 {2}", roomNumber, roomRight,probability));
        }


        /// <summary>
        /// 生成一個房間,內部包含23個隨機的生日
        /// </summary>
        /// <returns></returns>
        private static DateTime[] creatRoom()
        {
            DateTime[] people = new DateTime[23];
            for (int i = 0; i < people.Length; i++)
            {
                people[i] = creatBirsday();
            }
            roomNumber++;
            return people;
        }
        /// <summary>
        /// 隨機生成一個日期
        /// </summary>
        /// <returns></returns>
        private static DateTime creatBirsday()
        {
            int RandKey = ran.Next(0,365);
            DateTime dtBirsday = dt.AddDays(RandKey*(-1));
            return dtBirsday;
        }

        /// <summary>
        /// 檢驗房間內有生日重覆項
        /// </summary>
        /// <param name="dtBrisday"></param>
        /// <returns></returns>
        private static bool checkBirsday(DateTime[] dtBrisday)
        {
            for (int i = 0; i < dtBrisday.Length; i++)
            {
                int id = Array.IndexOf(dtBrisday, dtBrisday[i]); // 這裡的1就是你要查找的值
                if (id != -1 && id!=i)
                    return true;
            }
            return false;
        }
    }
}
View Code

 運行結果符合


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 之前我喜歡只是單純的記記筆記,沒有什麼寫文章的習慣,今天也是我一邊研究一邊學習,索性就連過程什麼的都記錄下吧,或許能幫到一兩個朋友呢。 首先,我們來想想什麼叫做單例,顧名思義,單一的一個對象,那麼,單一模式有什麼好處呢?比如說,你的對象只可以實例化一次等等。 先寫一個簡單的測試里的例子吧,比如我建一 ...
  • 本系列目錄: 《1、搜索有聲小說》 《2、分析詳細頁地址》 《3、批量下載mp3》 本篇是大結局,看過前兩篇的放心吧,不會有第四篇了,軟體的下載地址,軟體完成的效果大家自己看吧。 一、查找mp3文件的下載地址 我們首先要獲取其下載地址,在評書的詳細頁中沒有找到,我們進入播放頁面,看看能找到什麼,如下 ...
  • 百度:ef5 mysql http://my.oschina.net/u/170703/blog/210814?p=1 百度:dotconnect for mysql 破解 可以找到極限軟體網站上的 dcmysql的破解版 {"創建 entityFramework 的配置節處理程式時出錯: 未能載入 ...
  • 本篇之所以起這樣一個名字,是因為重點並非如何自定義控制項,不涉及創建CustomControl和UserControl使用的Template和XAML概念。而是通過繼承的方法來擴展一個現有的類,在繼承的子類中增加屬性和擴展行為。 我們在《UWP開發入門(七)——下拉刷新》中提到過嵌套ScrollVie ...
  • 一、Git簡介 1.Git是什麼 Git是分散式版本控制系統 2.Git有什麼特點 (1)Git是分散式的SCM,SVN是集中式的 (2)Git每個歷史版本存儲完整的文件,SVN存儲文件差異 (3)Git可離線完成大部分操作,SVN則相反 (4)Git有著更優雅的分支和合併實現 (5)Git有著更強... ...
  • 學習如何在MVC項目中配置AutoMapper。 一:首先在MVC項目中引用AutoMapper的DLL文件,接著創建一個介面,這裡面我們需要定義兩個方法,介面裡面的方法只能定義不能實現,也沒有什麼修飾符,實現介面的類必須實現裡面全部的方法。 定義介面IStartupTask,裡面有兩個方法。 pu... ...
  • 一、開發環境 編譯器:VS2013 .Net版本:4.5 二、開發過程 1.畫一條直線 private void btnDrawLine_Click(object sender, EventArgs e) { //創建一個畫圖圖面 Graphics g = this.CreateGraphics()... ...
  • 由於項目升級到了.NetFramework 4.6.1,開發工具轉向了vs2015,趁機嘗試下C#6.0.結果在網上搜的一些教程總結的不是太完整,有的代碼隨著vs正式版的發佈也有所修改.那些個教程也沒更新.所以把自己學習到的記錄一下. 1.自動屬性初始化(Auto-property initiali ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...