一道面試題引發(fā)的關于程序設計的想法
申明:這是在看到園子里兩個帖子關于兩道面試編程題之后個人的一點想法
面試題一:
大廳里有100盞燈,每盞燈都編了號碼,分別為1-100。每盞燈由一個開關來控制。(開關按一下,燈亮,再按一下燈滅。開關的編號與被控制的燈相同。)開始時,燈是全滅的?,F(xiàn)在按照以下規(guī)則按動開關。
***次,將所有的燈點亮。
第二次,將所有2的倍數(shù)的開關按一下。
第三次,將所有3的倍數(shù)的開關按一下。
以此類推。第N次,將所有N的倍數(shù)的開關按一下。
問第100次按完以后,大廳里還有幾盞燈是亮的。
看到這道題后我馬上想怎樣編程去實現(xiàn)這個問題
這道題不復雜很快我就想到一個實現(xiàn)的辦法,首先我寫了一個winform程序,界面用來展示各個燈***的狀態(tài)
***版的代碼如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
|
以下是運行結果
所以這就完了? 當然不是,然后我想到如果燈的數(shù)量跟要操作的次數(shù)是可變的呢,然后我開始重構這個方法,把可變的參數(shù)提取出來作為方法參數(shù)
修改后的代碼如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
|
下面是運行界面跟結果
看過《大話設計模式》的同學都知道到這里肯定沒完,比果我要實現(xiàn)2的倍數(shù)亮,3的倍數(shù)不亮怎么辦呢?
下面的留給各位自己想象去吧