C语言编程技巧分析 作者 kj第3章 循环结构编程技巧分析.pptVIP

C语言编程技巧分析 作者 kj第3章 循环结构编程技巧分析.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
3.3循环结构编程技巧分析 3.3.3 关于for循环结构的编程技巧分析 例3.7 采用近似计算的方法计算如下函数的定积分 。 分析:首先介绍近似计算方法。求定积分的近似值常有矩形法和梯形法,其实质都是面积求和。矩形法:将区间[a,b]上函数f(x)曲线与x轴所构成的面积沿x轴垂直划分成n个小矩形,所求的定积分的值即为这n个小矩形的面积相加。梯形法:将区间[a,b]上函数f(x)曲线与x轴所构成的面积沿x轴垂直划分成n个小梯形,对小梯形的面积求和。n值越大精度越高;n值相同时梯形法的精度高于矩形法。 本例采用梯形法计算定积分。 梯形的面积是:(上底+下底)×高/2。首先将[a,b]区间划分为n等份,每一等份的长度h=(b-a)/n就是梯形的高。 第*页 3.3循环结构编程技巧分析 3.3.3 关于for循环结构的编程技巧分析 例3.7 采用近似计算的方法计算如下函数的定积分 。 分析:每一等份的左侧值若用p变量存放,则右侧值为p+h,由函数f(x)可得其上底和下底分边为f(p)和f(p+h)。p的初始值为a,且上一等份的右侧取值是下一等份左侧的取值。n个梯形的面积求法是一样的,需要重复计算n个梯形的面积,可以用for循环语句实现。 关键是对近似法求积分的理解,在理解的基础上,该程序不难编写。今后碰到实际的问题时,分析求解的方法是很重要的。 第*页 请读者编写用矩形法求定积分的程序。 3.3循环结构编程技巧分析 3.3.3 关于for循环结构的编程技巧分析 例3.8 编程输出1~1000之间的所有同构数。所谓同构数是指一个数出现在它平方数的右端。如6出现在36的右端,则6是同构数;76出现在5776的右端,则76也是同构数。 #include stdio.h void main() {int i,s; for (i=1;i=999;i++) {if (i10) s=10; else if (i100) s=100; else s=1000; if((i*i)%s==i) printf(%d是同构数,其平方为%d\n,i,i*i); } } 第*页 3.3循环结构编程技巧分析 3.3.3 关于for循环结构的编程技巧分析 例3.8 编程输出1~1000之间的所有同构数。所谓同构数是指一个数出现在它平方数的右端。如6出现在36的右端,则6是同构数;76出现在5776的右端,则76也是同构数。 分析:有几种不同的方法判断同构数,本程序采用如下方法:若原数是个同构数,则原数是一位数时,原数平方后除以10的余数应该等于原数;原数是二位数时,原数平方后除以100的余数应该等于原数;原数是三位数时,原数平方后除以1000的余数应该等于原数。 本题使用for循环语句完成。在循环中,根据循环变量i是几位数,用一个if语句,确定变量s的值,为求余数运算做准备工作。因为1000不是同构数,所以循环变量i到999为止。 第*页 本题可以采用其它方法完成,请读者思考并编写程序。 3.3循环结构编程技巧分析 3.3.3 关于for循环结构的编程技巧分析 例3.9从键盘输入一个正数,判断这个数是否是素数。 #include stdio.h #include math.h void main() {int a,i,k,mark=1; scanf(%d, a); k=sqrt(a); for (i=2;i=k;i++) if (a%i==0) {mark=0; break; } if((mark==1) printf(%d是素数。\n,a); if((mark==0) printf(%d不是素数。\n,a); } 第*页 3.3循环结构编程技巧分析 3.3.3 关于for循环结构的编程技巧分析 例3.9从键盘输入一个正数,判断这个数是否是素数。 分析:从键盘输入的正数存放在a中,变量k存放a的平方根。根据数学理论,a若能被2到k之间的某个整数多整除,则a不是素数,否则a是素数。所以可以用2到k之间的整数按顺序检验能否整除a,循环次数明确,使用for循环编写比较好。在循环内使用了break语句,一旦在某次中,a被某个数整除了,说明a不是素数,即可结束循环了。 程序中使用了一个特殊的变量mark,它被称为标志变量。标志变量可以取几个特定的值,每个值代表一种状态。在本程序中,mark可以取1或0这两个值,mark取1代表a是素数,mark取0代表a不是素数。请读者通过本程序学会运用标志变量。 第*页 3.3循环结构编程技巧分析 3.3.4关于循环嵌套结构编程技巧分析 当考虑第一种因

文档评论(0)

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档