Office中國(guó)論壇/Access中國(guó)論壇

 找回密碼
 注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

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

[模塊/函數(shù)] 【新手進(jìn)階】之一:基礎(chǔ)算法(一)

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
1#
發(fā)表于 2015-1-26 15:51:28 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式

看到這題目,大家第一反應(yīng)可能是,我需要學(xué)嗎?跟編程有關(guān)系嗎?對(duì)于這兩個(gè)問(wèn)題,我的回答是:不需要學(xué),但建議學(xué);跟編程有關(guān)系,但并非充分條件。就好比下象棋,不懂棋譜,不代表不能贏,但在殺法上可能就有區(qū)別了,懂棋譜的可能更容易妙招迭出;同樣地,不懂算法,不代表不會(huì)編程。不過(guò),如果想編寫(xiě)出一個(gè)更優(yōu)雅的程序,還是學(xué)學(xué)算法吧。

說(shuō)到算法,大多數(shù)都顯得枯燥艱澀,向來(lái)曲高和寡。其實(shí),算法也并不是那么復(fù)雜,現(xiàn)在我手頭上這本就淺顯易懂得多了,只是不知道為什么市面上關(guān)于這方面的書(shū)籍都是那么無(wú)趣。只是,這個(gè)日本人定位的是科普讀物,所以,代碼部分只能由我動(dòng)手寫(xiě)了(當(dāng)然,算法中的變量名稱(chēng)也根據(jù)我寫(xiě)的函數(shù)來(lái)定的)。

先申明一下,這部分只說(shuō)基礎(chǔ)算法,不涉及任何技巧,所以不要拿數(shù)學(xué)或者系統(tǒng)函數(shù)等等來(lái)說(shuō)事兒。

關(guān)于自然數(shù)求和:

  • 先列出步驟:
  • 先將結(jié)果lngRes初始化為0。
  • 對(duì)lngRes求和,i為加數(shù)。
  • 重復(fù)執(zhí)行4、5,直至i>intN。
  • 計(jì)算lngRes+i的值,存入lngRes里。
  • 每次i值加1。

根據(jù)步驟寫(xiě)下的代碼是:

  1. Function getSum(ByVal intN As Long) As Long
  2. Dim i As Long
  3. Dim lngRes As Long
  4. Do Until i > intN
  5.            lngRes = lngRes + i
  6.            i = i + 1
  7. Loop
  8. getSum = lngRes
  9. End Function
復(fù)制代碼

至此,第一個(gè)算法就算完成了。很簡(jiǎn)單是嗎?接下來(lái),以斐波那契數(shù)列為例,簡(jiǎn)單介紹下遞歸算法(這里不打算細(xì)說(shuō),詳細(xì)請(qǐng)參考之前我發(fā)的帖子),步驟如下:

  • 令數(shù)組s(0)=0,s(1)=1。
  • i從2開(kāi)始。
  • 當(dāng)i<=intN時(shí),重復(fù)執(zhí)行步驟4、5。
  • 令s(i)=s(i-1)+s(i-2)
  • 每次i+1

按照步驟,可以定義一個(gè)從s(2 to intN)的數(shù)組,不過(guò)考慮到我們還預(yù)先定義了s(0)和s(1),所以干脆定義一個(gè)s(intN)【大部分?jǐn)?shù)組都是默認(rèn)序號(hào)從0開(kāi)始的】,在執(zhí)行循環(huán)時(shí)區(qū)分開(kāi)來(lái)即可。于是有:

  1. Function getFib(ByVal intN As Long) As Long
  2. Dim i As Long
  3. Dim s() As Long
  4. ReDim s(intN)
  5. For i = 0 To intN
  6.            If i = 0 Then
  7.                       s(i) = 0
  8.            ElseIf i = 1 Then
  9.                      s(i) = 1
  10.             Else
  11.                     s(i) = s(i - 1) + s(i - 2)
  12.            End If
  13. Next
  14. getFib = s(intN)
  15. End Function
復(fù)制代碼

示例文件

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

【新手入門(mén)】之九:從百錢(qián)百雞談起——淺談“規(guī)劃求解”兼答lingjiang問(wèn)
【新手入門(mén)】之十:書(shū)到用時(shí)方恨少——自定義菜單(Access 2003)的制作
【新手入門(mén)】之十一:淺談ADO之序言
【新手入門(mén)】之十二:淺談ADO之Connection
【新手入門(mén)】之十三:淺談ADO之Conmmand(上)
【新手入門(mén)】之十四:淺談ADO之Command(下)
【新手入門(mén)】之十五:淺談ADO之Recordset(上)
【新手入門(mén)】之十六:淺談ADO之Recordset(下)
【新手入門(mén)】之十七:淺談列表框的使用
【新手入門(mén)】之十八:雙擊列表框修改數(shù)據(jù)
【新手入門(mén)】之十九:從“書(shū)與女友恕不外借”談起——淺談“Bookmark”的使用
【新手入門(mén)】之二十:“書(shū)與書(shū)簽”——bookmark屬性答疑
【新手入門(mén)】之二十一:記錄集的“凌遲”——逐條導(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ì)算
【新手進(jìn)階】之十一:“庖丁解!焙汀凹o(jì)昌學(xué)射”——淺談表格式文本數(shù)據(jù)的導(dǎo)入
【新手進(jìn)階】之十二:從四腳騰空的奔馬談起——原來(lái)界面可以這樣設(shè)計(jì)
【新手進(jìn)階】之十三:Outlook風(fēng)格導(dǎo)航界面
【新手進(jìn)階】之十四:倉(cāng)庫(kù)管理系統(tǒng)

評(píng)分

參與人數(shù) 1經(jīng)驗(yàn) +18 收起 理由
todaynew + 18 幸苦了

查看全部評(píng)分

本帖被以下淘專(zhuān)輯推薦:

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享分享 分享淘帖1 訂閱訂閱
2#
發(fā)表于 2015-1-26 16:42:25 | 只看該作者
文字有些偏多,讀起來(lái)有些不易。
3#
發(fā)表于 2015-1-26 17:00:04 | 只看該作者
迫切需要掃盲.感謝斑竹.
文字確多,已經(jīng)習(xí)慣淺閱讀了.
4#
 樓主| 發(fā)表于 2015-1-26 17:03:43 | 只看該作者
看來(lái)還是拆開(kāi)好點(diǎn)~~~
5#
發(fā)表于 2015-1-26 17:10:58 | 只看該作者
{:soso_e100:}主要是電子屏看久了眼睛很難受

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

6#
發(fā)表于 2015-1-26 18:55:28 | 只看該作者
聽(tīng)說(shuō)算法是一個(gè)軟件的靈魂
7#
發(fā)表于 2015-1-27 09:52:38 | 只看該作者
我一直在看你發(fā)的貼!
8#
 樓主| 發(fā)表于 2015-1-27 09:56:59 | 只看該作者
天涯淪落20131 發(fā)表于 2015-1-27 09:52
我一直在看你發(fā)的貼!

多謝支持!
9#
發(fā)表于 2016-1-5 22:45:49 | 只看該作者
喜歡掃盲, 代碼看了好幾遍才懂了
10#
發(fā)表于 2018-6-8 17:05:10 | 只看該作者
xiexie
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則

QQ|站長(zhǎng)郵箱|小黑屋|手機(jī)版|Office中國(guó)/Access中國(guó) ( 粵ICP備10043721號(hào)-1 )  

GMT+8, 2025-7-13 02:26 , Processed in 0.100565 second(s), 39 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

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