設(shè)為首頁收藏本站Access中國

Office中國論壇/Access中國論壇

 找回密碼
 注冊

QQ登錄

只需一步,快速開始

返回列表 發(fā)新帖
查看: 9523|回復(fù): 8
打印 上一主題 下一主題

[模塊/函數(shù)] 【新手入門】之九:從百錢百雞談起——淺談“規(guī)劃求解”兼答lingjiang問

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
1#
發(fā)表于 2013-1-16 13:00:42 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
       昨晚看了版友lingjiang在論壇里喊“救命”(詳見http://m.mzhfr.cn/thread-116347-1-1.html),本著“救人一命勝造七級浮屠”的人道主義,便出來看看熱鬧,結(jié)果讓我想起了小時候的一件事:
       那時候還算乖巧吧,建房子的時候,工人們常常喜歡出點刁鉆的問題來考我。印象最深的莫過于百錢百雞問題了:公雞三元一只,母雞一元一只,小雞一元三只,現(xiàn)以百錢買百雞,求各雞數(shù)。

       可憐當(dāng)時俺才小學(xué)四年級。別說三元一次方程,連二元一次方程都沒學(xué)過。不過我還是算出來了(說這里,大家是不是很佩服Roych呢?{:soso_e113:})我的算法很簡單,當(dāng)然也很笨:
       就是假定先拿全部的錢去買公雞,可以買33只,100-33*3=1元可以買3只小雞。接下來就簡單了,把買公雞的數(shù)量逐步減下來,換成小雞的。乖乖,第一組答案出來了:25,0,75。
       這時候有人可能會說了,不是沒買母雞嗎?非要買母雞?因為想吃雞蛋?干嗎不買雞蛋?……算了算了,公雞再少買1只好了。先換成小雞:24,0,84。接下來,同樣地把小雞換成母雞,于是得到:24,7,69

       從上面,大家也可以看得出,這種笨方法其實是一種取巧的方法,先簡化了變量,由3個變成2個(不買母雞),再由2個變成1個(公雞換小雞),同樣地,用小雞換母雞時也是先把公雞設(shè)定為常量(24),再由母雞和小雞之間轉(zhuǎn)換。
      學(xué)了編程之后,才知道這種算法思想叫做“窮舉法”,對付這類型的規(guī)劃求解相當(dāng)有效。當(dāng)然,以我當(dāng)時的智商,也只列出一組解罷了。把這個問題寫成程序大概是這樣:
  1. Sub getChicken()
  2. Dim a%, b%, c%
  3. For a = 0 To 33
  4.        For b = 1 To 100
  5.              c = 100 - a - b
  6.              If a * 3 + b + c / 3 = 100 Then
  7.                      Debug.Print a, b, c
  8.              End If
  9.        Next
  10. Next
  11. End Sub
復(fù)制代碼
我們現(xiàn)在再回頭看看lingjiang的問題,ta所提到的隨機(jī)數(shù)組,算是一個百錢百雞問題,總和雖然不是固定的,但也算是“百錢”(總成績)了,“雞”的定價也定了,“小雞”是0.2元一只(平時成績),“公雞”和“母雞”(期中成績和期末成績)是0.4元一只。為了數(shù)據(jù)上的好看,我加了一條:每種“雞”至少得買60只(至少得及格吧?)。
      用上面的程序行嗎?顯然沒問題。只是應(yīng)該多加一個變量(總成績)而已。不過,有必要嗎?顯然沒必要。我們只需要列出一組解就好了。因此,寫了以下程序:
  1. Sub getRnd()
  2. '定義分變量
  3. Dim lngSum As Long
  4. Dim lngS0, lngS1 As Long, lngS2 As Long, lngS3 As Long
  5. '總分?jǐn)?shù),可以自行定義。
  6. lngSum = 90
  7. '確保兩個分變量在60-100之間。
  8. lngS1 = 60 + Rnd * 40
  9. lngS2 = 60 + Rnd * 40
  10. '確定第三個分變量,并保證在100以內(nèi)。
  11. If (lngSum - lngS1 * 0.2 - lngS2 * 0.4) > 40 Then
  12.       lngS2 = lngS2 + (lngSum - lngS1 * 0.2 - lngS2 * 0.4) / 0.4 - 100
  13.       lngS3 = 100
  14. Else
  15.       lngS3 = (lngSum - lngS1 * 0.2 - lngS2 * 0.4) / 0.4
  16. End If
  17. '微調(diào)
  18. If lngS1 * 0.2 + lngS2 * 0.4 + lngS3 * 0.4 < 90 Then
  19.      lngS1 = lngS1 + 1
  20. End If
  21. '顯示分變量
  22. Debug.Print lngS1, lngS2, lngS3
  23. '驗算
  24. Debug.Print lngS1 * 0.2 + lngS2 * 0.4 + lngS3 * 0.4
  25. End Sub
復(fù)制代碼

【新手入門】之一:If分支語句
【新手入門】之二:分支語句總結(jié)
【新手入門】之三:循環(huán)語句For
【新手入門】之四:循環(huán)語句Do和死循環(huán)
【新手入門】之五:公共變量與傳址過程、傳值過程
【新手入門】之六:“悲歡離合總無情”——淺談Split和Join
【新手入門】之七:嵌套與并列——再談If流程問題
【新手入門】之八:“連就連”——淺談“&”和“+”連接符的區(qū)別

【新手入門】之九:從百錢百雞談起——淺談“規(guī)劃求解”兼答lingjiang問
【新手入門】之十:書到用時方恨少——自定義菜單(Access 2003)的制作
【新手入門】之十一:淺談ADO之序言
【新手入門】之十二:淺談ADO之Connection
【新手入門】之十三:淺談ADO之Conmmand(上)
【新手入門】之十四:淺談ADO之Command(下)
【新手入門】之十五:淺談ADO之Recordset(上)
【新手入門】之十六:淺談ADO之Recordset(下)
【新手入門】之十七:淺談列表框的使用
【新手入門】之十八:雙擊列表框修改數(shù)據(jù)
【新手入門】之十九:從“書與女友恕不外借”談起——淺談“Bookmark”的使用
【新手入門】之二十:“書與書簽”——bookmark屬性答疑
【新手入門】之二十一:記錄集的“凌遲”——逐條導(dǎo)出記錄集

【新手進(jìn)階】之一:基礎(chǔ)算法(一)
【新手進(jìn)階】之二:基礎(chǔ)算法(二)
【新手進(jìn)階】之三:基礎(chǔ)算法(三)
【新手進(jìn)階】之四:基礎(chǔ)算法(四)
【新手進(jìn)階】之五:排序搜索(一)
【新手進(jìn)階】之六:排序搜索(二)
【新手進(jìn)階】之七:遞歸算法
【新手進(jìn)階】之八:冒泡排序
【新手進(jìn)階】之九:淺談不綁定數(shù)據(jù)源操作記錄
【新手進(jìn)階】之十:工作日的計算
【新手進(jìn)階】之十一:“庖丁解!焙汀凹o(jì)昌學(xué)射”——淺談表格式文本數(shù)據(jù)的導(dǎo)入
【新手進(jìn)階】之十二:從四腳騰空的奔馬談起——原來界面可以這樣設(shè)計
【新手進(jìn)階】之十三:Outlook風(fēng)格導(dǎo)航界面
【新手進(jìn)階】之十四:倉庫管理系統(tǒng)

本帖子中包含更多資源

您需要 登錄 才可以下載或查看,沒有帳號?注冊

x

本帖被以下淘專輯推薦:

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享分享 分享淘帖1 訂閱訂閱
2#
發(fā)表于 2013-1-16 13:26:33 | 只看該作者
多謝

3#
發(fā)表于 2013-1-16 13:57:33 | 只看該作者
厲害{:soso_e179:}

點擊這里給我發(fā)消息

4#
發(fā)表于 2013-1-16 14:21:28 | 只看該作者
學(xué)習(xí)了!

點擊這里給我發(fā)消息

5#
發(fā)表于 2013-1-16 14:54:14 | 只看該作者
謝謝分享!
6#
發(fā)表于 2013-1-16 14:56:02 | 只看該作者
roych 真厲害!
7#
發(fā)表于 2013-1-17 09:42:58 | 只看該作者
謝謝分享!
8#
發(fā)表于 2013-1-17 11:29:51 | 只看該作者
roych 真厲害!
9#
發(fā)表于 2016-1-17 05:53:49 | 只看該作者
從百錢百雞談起——淺談“規(guī)劃求解”兼答lingjiang問
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則

QQ|站長郵箱|小黑屋|手機(jī)版|Office中國/Access中國 ( 粵ICP備10043721號-1 )  

GMT+8, 2025-7-13 02:28 , Processed in 0.109614 second(s), 36 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回復(fù) 返回頂部 返回列表