版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、VB常用算法-累加和连乘一、算法说明 累加形式:V=V+e连乘形式:V=V*e其中:V是变量,e是递增表达式。累加和连乘一般通过循环结构来实现。注意:需在执行循环体前对变量V赋初值。一般的,累加时置初值0;连乘时置初值为1。举例说明:求N! 的结果。Private Sub Command1_Click() Dim n%, i%, s& n = Val(InputBox(输入n) s = 1 For i = 1 To n s = s * i Next i Print sEnd Sub错误的写法:Private Sub Command1_Click() Dim n%, i%, s& n = Val
2、(InputBox(输入n) For i = 1 To n s = 1 赋初值语句位置不对!s = s * i Next i Print s 输出s的值为n,而不是n!End Sub二、应用举例例1. 根据下列公式,求自然对数e的的近似值。要求:误差小于0.00001Private Sub Command1_Click() Dim i%, n&, t!, e! e = 2 i = 1 t = 1 Do While t 0.00001 i = i + 1 t = t / i e = e + t Loop Print 计算; i+1; 项后,自然对数e值为:; e Print Exp(1) 与上句
3、输出值进行对比以证明算法的正确性End Sub解题技巧1) 由于这类题目往往是根据精度要求来求值,因此我们不能预知具体循环次数,所以这类题目一般用Do循环,很少用For循环。设定循环变量i和通项变量t,注意各变量的初值;2) 分解通项表达式中各因子,并分别将各因子用循环变量表示;3) 如果步骤2中有的因子比较复杂,难以直接用变量表示,此时可以考虑使用Function过程;4) 根据步骤1、2、3,写出通项表达式;5) 根据精度要求(往往是通项小于10负多少次方这样一个关系表达式),写出一条满足精度要求后跳出循环的语句。通常是用:if 通项表达式10(-N) then exit do ,注意这句
4、话一般需放在累加或者连乘式之前。例2. 以2002年春上机试卷06编程题为例根据X值计算:n1,2,要求:n项绝对值小于等于10-6为止。1) 由于循环次数不确定,因此确定用Do循环结构并定义循环变量用n表示(初值1);用户输入的值用x表示;通项用dblCos表示;累加值用sum表示,初值为0;2) 分解通项式的组成可以分解为三部分: 可以表示为:(1)(n+1) 可以表示为:x(2*(n-1) 比较复杂,难以直接表示3) 由于步骤2中 复杂, 此时考虑使用过程实现。定义过程,输入值是n,返回值是 于是有:private Function comp(n as long)as longdim I
5、 as longdim result as longresult=1 此处注意,由于是连乘,初值为1for I=1 to 2*(n-1)result=result*Inext Icomp=resultEnd Function注意:由于是参数按地址传递,因此对于本题,实参的值不能在过程中被改变!(也是改错题常考的地方!)4) 根据步骤1、2、3,写出通项dblCos的表达式:dblCos=(1)(n+1)* x(2*(n-1)/comp(n)5) 根据精度要求知:If abs(dblCos)=10(-6) then exit do 最后程序为:Option ExplicitPrivate Sub
6、 Command1_Click() Dim n As Long, dblCos As Double, x As Double Dim sum As Double x = Val(Text1.Text) n = 1 Do dblCos = (-1) (n + 1) * x (2 * (n - 1) / comp(2 * (n - 1) If Abs(dblCos) = 10 (-6) Then Exit Do sum = sum + dblCos n = n + 1 Loop Text2.Text = sumEnd SubPrivate Function comp(n As Long) As L
7、ong Dim I As Long Dim result As Long result = 1 此处注意,由于是连乘,初值为1 For I = 1 To n result = result * I Next I comp = resultEnd Function注意:如果调试运行时出现死循环,可以按CtrlBreak中断死循环,不需要重新启动机器。(或者Ctrl+Scroll Lock)三、实战练习 1) 完善程序填空(2003秋二(7)本程序的功能是求下面数列前n项之和。S(x,n)=x/2+2!*x3/2*4+3!*x5/2*4*6+.+n!*x2n-1/2*4*6.2nOption ExplicitPrivate Sub Command1_Click()Dim x As Single , s As SingleDim n As Integer , i As Integerx=InputBox(输入:,求数列和,)n=InputBox(输入:,求数列和,)For i=1 To ns=s+fun(x,i)Next iLabel1.Caption= (1)Text1=sEnd SubPrivate Function fun(x As Single , n As Integer) As Single D
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025浙江温州苍南县卫生健康系统第二轮面向社会招聘编外辅助人员4人考试笔试模拟试题及答案解析
- 2025昆明市晋宁区市场监督管理局招聘编外工作人员(1人)笔试考试参考试题及答案解析
- 2025海南省金城安居投资集团有限公司第四期人才招聘9人笔试考试参考题库及答案解析
- 2025年安徽中医药大学招聘博士辅导员4人笔试考试备考试题及答案解析
- 2025中国海洋大学海洋与大气学院实验技术人员招聘1人(山东)笔试考试备考试题及答案解析
- 2025江西吉安吉州区北门街道社区卫生服务中心招募就业见习人员3人笔试考试参考题库及答案解析
- 2025浙江绍兴市凯泰特种纤维科技有限公司招聘4人考试笔试备考题库及答案解析
- 2025河北医科大学第一医院医疗工作人员招聘15人笔试考试备考试题及答案解析
- 2025年新能源行业企业数字化转型与人力资源组织架构优化策略
- 2026陕西省面向东北大学招录选调生考试笔试参考题库附答案解析
- 劲嘉集团SAP项目-业务现状及需求调研报告-FICO-V1.2(中丰田)-20180625
- 文物保护工程资料管理规程
- 产品量产问题总结汇报
- 优质课点评发言稿(一)
- 2022版HPZ440工作站技术手册指南
- 学术伦理教育与培训
- 迪庆藏族自治州发电有限责任公司新乐水电站环境影响后评价报告书
- 易制爆化学品使用操作流程
- 2022秋思想道德与法治学习通超星课后章节答案期末考试题库2023年
- 2019年春季马克思主义基本原理概论课程社会实践报告大学生应该如何看待及应对人工智能的发展
- 工业管道sch壁厚等级对照表优质资料
评论
0/150
提交评论