java抽象-老師的生日-邏輯思維-有趣的面試題-遁地龍卷風

来源:http://www.cnblogs.com/resolvent/archive/2016/09/30/5924806.html
-Advertisement-
Play Games

(-1)寫在前面 都快去北京了,硬生生的安排一場java考試,對於那些特別細節的東西我忘了吧也不覺得有什麼不好,以前都記得,也都見過,只不過平時不常用連接斷了,但是你死記硬背是沒用的,一段時間後還是會忘,唯一的途徑就是多做東西,理論聯繫實際,相反這道題我感覺很有意思,也在網上看到了很多解釋,覺得都有 ...


(-1)寫在前面

都快去北京了,硬生生的安排一場java考試,對於那些特別細節的東西我忘了吧也不覺得有什麼不好,以前都記得,也都見過,只不過平時不常用連接斷了,但是你死記硬背是沒用的,一段時間後還是會忘,唯一的途徑就是多做東西,理論聯繫實際,相反這道題我感覺很有意思,也在網上看到了很多解釋,覺得都有所不足,下麵是我給出的答案。

(0)詳細解釋

設一個老師的生日為M月N日.把M告訴學生甲(即學生甲知道老師出生的月份),把N告訴學生乙(即學生乙知道老師出生的日).現有如下日期是公開的:3月4日,3月8日,3月10日,6月4日,6月7日,9月1日,9月10日,12月1日,12月2日,12月8日

其中有一個是老師的生日.

 

現有學生甲與學生乙的對話:

學生甲:如果我不知道的話,你一定不知道.

學生乙:本來我不知道的,現在我知道了.

學生甲:那我也知道了.

現在問:老師的生日是哪一天?

甲的第一句話

首先我們看數據有哪些特性,數據是由月份和日期組成的,甲是知道月份的,數據中的月份有3,6,9,12,甲不能通過自己知道的月份信息判斷出老師的生日,甲知道乙無法通過日期推測出正確的月份。

甲知道的是3 月 日期有4,8,10

甲知道的是6月 日期有4,7

甲知道的是9 月 日期有1,10

甲知道的是12月  日期有2,8

我們發現7日、2日是唯一的,也就說明,如果甲知道的是六月,那麼乙知道的是7日,就推測出生日,甲就不會說你一定不知道,所以甲知道的不是6月,同理,甲知道的也不是12月。

乙的第一句話

根據甲的第一句話,剩餘數據如下:

甲知道的是3 月 日期有4,8,10

甲知道的是9 月 日期有1,10

乙的前半句話有歧義,第一種情況,乙認為甲能夠通過月份推出生日,那麼乙的日期就是2或7,這與甲第一句話得出的結論不符。那麼就是第二種情況,乙此時通過甲的話推斷出上述結論,根據自己的日期判斷出了甲的月份,顯然10是不對的,如果是10,甲的月份就不唯一。那麼數據如下:

甲知道的是3 月 日期有4,8

甲知道的是9 月 日期有1

這樣看來似乎3月4日,3月8日,9月1日都是可以的,因為乙知道1,4,8中的任意一個對應的月份都是唯一的

甲的第二句話

這句話把答案推向了9月1日,因為對於甲來講,如果他知道的是3月,對於老師的生日就3月4日和3月8日兩種選擇,而如果他知道的是9月,就只有9月1日這一種答案。


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

-Advertisement-
Play Games
更多相關文章
  • VSCode,安裝插件:C# for Visual Studio Code (powered by OmniSharp),關於C#代碼的插件提示後,提示安裝DotNetCore.1.0.1 在安裝DotNetCore.1.0.1-VS2015Tools.Preview2.0.2出現0x80072f8... ...
  • 這個屬性我們平時可能並不怎麼用.先來看下MSDN上的解釋: 解釋的非常專業,然而我並沒有看懂. 說說我的理解吧:把這個屬性設置為false,看起來沒有變化,但操作上已經把他完全忽視了,不觸發事件,可以直接點到它下麵的東西. 這個屬性能方便的解決工作中常見的麻煩,比如下麵這個例子: 註意上面那部分.效 ...
  • 轉自:http://blog.csdn.net/samsone/article/details/7556781 1、格式化貨幣(跟系統的環境有關,中文系統預設格式化人民幣,英文系統格式化美元) string.Format("{0:C}",0.2) 結果為:¥0.20 (英文操作系統結果:$0.20) ...
  • 前段時間,我負責一款APP的介面開發,其中有一個新增的操作,邏輯比較複雜,涉及到9個數據表的數據改動,而且表又跨庫,這9個表呢,個別在別處還有單表操作,所以為了復用之前的數據層,筆者直接想到了使用分散式事務TransactionScope,在業務層直接調用多個DAO類的方法。 再說下這個新增操作吧, ...
  • 之前一直認為因為List內部實現是數組,ToArray的實現只是將數組返回出去而已。 今天測了一下發現並不是那樣 1萬數量大小的List,調用1萬次ToArray的時間消耗是417ms左右。 報著疑惑看了下源碼,沒想到它是把內部數組複製了一份再返回 看來對於重覆性操作,可以考慮直接緩存成全局變數,或 ...
  • 什麼是基元類型? 什麼是基元類型? 初學者可能很少聽說過這個名詞,但是平時用得最多的肯定是基元類型。先看下麵兩行代碼: 上面兩行代碼都表示聲明一個int類型的變數,但在平時寫代碼的時候我們一般用的是第二種方式。第二種方式不僅簡潔、易讀,而且生成的IL代碼和第一種完全一致。像這種編譯器直接支持的數據類 ...
  • 1. 類的訪問修飾符 2. 成員修飾符 ...
  • 1、頁面上按鈕是伺服器控制項,現在刷新頁面要防止按鈕事件重覆執行 原網址:http://blog.csdn.net/high_mount/article/details/51066056 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...