设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 6397|回复: 9
打印 上一主题 下一主题

[模块/函数] 【新手进阶】之一:基础算法(一)

[复制链接]
跳转到指定楼层
1#
发表于 2015-1-26 15:51:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

看到这题目,大家第一反应可能是,我需要学吗?跟编程有关系吗?对于这两个问题,我的回答是:不需要学,但建议学;跟编程有关系,但并非充分条件。就好比下象棋,不懂棋谱,不代表不能赢,但在杀法上可能就有区别了,懂棋谱的可能更容易妙招迭出;同样地,不懂算法,不代表不会编程。不过,如果想编写出一个更优雅的程序,还是学学算法吧。

说到算法,大多数都显得枯燥艰涩,向来曲高和寡。其实,算法也并不是那么复杂,现在我手头上这本就浅显易懂得多了,只是不知道为什么市面上关于这方面的书籍都是那么无趣。只是,这个日本人定位的是科普读物,所以,代码部分只能由我动手写了(当然,算法中的变量名称也根据我写的函数来定的)。

先申明一下,这部分只说基础算法,不涉及任何技巧,所以不要拿数学或者系统函数等等来说事儿。

关于自然数求和:

  • 先列出步骤:
  • 先将结果lngRes初始化为0。
  • 对lngRes求和,i为加数。
  • 重复执行4、5,直至i>intN。
  • 计算lngRes+i的值,存入lngRes里。
  • 每次i值加1。

根据步骤写下的代码是:

  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
复制代码

至此,第一个算法就算完成了。很简单是吗?接下来,以斐波那契数列为例,简单介绍下递归算法(这里不打算细说,详细请参考之前我发的帖子),步骤如下:

  • 令数组s(0)=0,s(1)=1。
  • i从2开始。
  • 当i<=intN时,重复执行步骤4、5。
  • 令s(i)=s(i-1)+s(i-2)
  • 每次i+1

按照步骤,可以定义一个从s(2 to intN)的数组,不过考虑到我们还预先定义了s(0)和s(1),所以干脆定义一个s(intN)【大部分数组都是默认序号从0开始的】,在执行循环时区分开来即可。于是有:

  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
复制代码

示例文件

【新手入门】之一:If分支语句
【新手入门】之二:分支语句总结
【新手入门】之三:循环语句For
【新手入门】之四:循环语句Do和死循环
【新手入门】之五:公共变量与传址过程、传值过程
【新手入门】之六:“悲欢离合总无情”——浅谈Split和Join
【新手入门】之七:嵌套与并列——再谈If流程问题
【新手入门】之八:“连就连”——浅谈“&”和“+”连接符的区别

【新手入门】之九:从百钱百鸡谈起——浅谈“规划求解”兼答lingjiang问
【新手入门】之十:书到用时方恨少——自定义菜单(Access 2003)的制作
【新手入门】之十一:浅谈ADO之序言
【新手入门】之十二:浅谈ADO之Connection
【新手入门】之十三:浅谈ADO之Conmmand(上)
【新手入门】之十四:浅谈ADO之Command(下)
【新手入门】之十五:浅谈ADO之Recordset(上)
【新手入门】之十六:浅谈ADO之Recordset(下)
【新手入门】之十七:浅谈列表框的使用
【新手入门】之十八:双击列表框修改数据
【新手入门】之十九:从“书与女友恕不外借”谈起——浅谈“Bookmark”的使用
【新手入门】之二十:“书与书签”——bookmark属性答疑
【新手入门】之二十一:记录集的“凌迟”——逐条导出记录集

【新手进阶】之一:基础算法(一)
【新手进阶】之二:基础算法(二)
【新手进阶】之三:基础算法(三)
【新手进阶】之四:基础算法(四)
【新手进阶】之五:排序搜索(一)
【新手进阶】之六:排序搜索(二)
【新手进阶】之七:递归算法
【新手进阶】之八:冒泡排序
【新手进阶】之九:浅谈不绑定数据源操作记录
【新手进阶】之十:工作日的计算
【新手进阶】之十一:“庖丁解牛”和“纪昌学射”——浅谈表格式文本数据的导入
【新手进阶】之十二:从四脚腾空的奔马谈起——原来界面可以这样设计
【新手进阶】之十三:Outlook风格导航界面
【新手进阶】之十四:仓库管理系统

评分

参与人数 1经验 +18 收起 理由
todaynew + 18 幸苦了

查看全部评分

本帖被以下淘专辑推荐:

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2 分享分享 分享淘帖1 订阅订阅
2#
发表于 2015-1-26 16:42:25 | 只看该作者
文字有些偏多,读起来有些不易。
3#
发表于 2015-1-26 17:00:04 | 只看该作者
迫切需要扫盲.感谢斑竹.
文字确多,已经习惯浅阅读了.
4#
 楼主| 发表于 2015-1-26 17:03:43 | 只看该作者
看来还是拆开好点~~~
5#
发表于 2015-1-26 17:10:58 | 只看该作者
{:soso_e100:}主要是电子屏看久了眼睛很难受

点击这里给我发消息

6#
发表于 2015-1-26 18:55:28 | 只看该作者
听说算法是一个软件的灵魂
7#
发表于 2015-1-27 09:52:38 | 只看该作者
我一直在看你发的贴!
8#
 楼主| 发表于 2015-1-27 09:56:59 | 只看该作者
天涯沦落20131 发表于 2015-1-27 09:52
我一直在看你发的贴!

多谢支持!
9#
发表于 2016-1-5 22:45:49 | 只看该作者
喜欢扫盲, 代码看了好几遍才懂了
10#
发表于 2018-6-8 17:05:10 | 只看该作者
xiexie
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-15 01:23 , Processed in 0.087782 second(s), 37 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表