电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本

c+c++语言经典、实用、趣味程序设计编程

121页
  • 卖家[上传人]:小**
  • 文档编号:89123025
  • 上传时间:2019-05-18
  • 文档格式:DOC
  • 文档大小:280KB
  • / 121 举报 版权申诉 马上下载
  • 文本预览
  • 下载提示
  • 常见问题
    • 1、C/C+语言经典、实用、趣味程序设计编程百例精解(1)1.绘制余弦曲线 在屏幕上用“*”显示0360度的余弦函数cos(x)曲线 *问题分析与算法设计如果在程序中使用数组,这个问题十分简单。但若规定不能使用数组,问题就变得不容易了。关键在于余弦曲线在0360度的区间内,一行中要显示两个点,而对一般的显示器来说,只能按行输出,即:输出第一行信息后,只能向下一行输出,不能再返回到上一行。为了获得本文要求的图形就必须在一行中一次输出两个“*”。为了同时得到余弦函数cos(x)图形在一行上的两个点,考虑利用cos(x)的左右对称性。将屏幕的行方向定义为x,列方向定义为y,则0180度的图形与180360度的图形是左右对称的,若定义图形的总宽度为62列,计算出x行0180度时y点的坐标m,那么在同一行与之对称的180360度的y点的坐标就 应为62-m。程序中利用反余弦函数acos计算坐标(x,y)的对应关系。使用这种方法编出的程序短小精炼,体现了一定的技巧。 *程序说明与注释#include#includeint main()double y;int x,m;for(y=1;y=-1;y-=0

      2、.1) /*y为列方向,值从1到-1,步长为0.1*/m=acos(y)*10; /*计算出y对应的弧度m,乘以10为图形放大倍数*/for(x=1;xm;x+) printf( );printf(*); /*控制打印左侧的 * 号*/for(;x62-m;x+)printf( );printf(*n); /*控制打印同一行中对称的右侧*号*/ return 0; *思考题如何实现用“*”显示0360度的sin(x)曲线。 在屏幕上显示0360度的cos(x)曲线与直线f(x)=45*(y-1)+31的迭加图形。其中cos(x)图形用“*”表示,f(x)用“+”表示,在两个图形相交的点上则用f(x)图形的符号。 2.绘制余弦曲线和直线 *问题分析与算法设计本题可以在上题的基础上进行修改。图形迭加的关键是要在分别计算出同一行中两个图形的列方向点坐标后,正确判断相互的位置关系。为此,可以先判断图形的交点,再分别控制打印两个不同的图形。 *程序注释与说明#include#include int main()double y;int x,m,n,yy;for(yy=0;yy=20;yy+) /

      3、*对于第一个y坐标进行计算并在一行中打印图形*/y=0.1*yy; /*y:屏幕行方向坐标*/m=acos(1-y)*10; /*m: cos(x)曲线上y点对应的屏幕列坐标*/n=45*(y-1)+31; /*n: 直线上y点对应的列坐标*/for(x=0;x=62;x+) /*x: 屏幕列方向坐标*/if(x=m&x=n) printf(+); /*直线与cos(x)相交时打印“+”*/else if(x=n) printf(+); /*打印不相交时的直线图形*/else if(x=m|x=62-m) printf(*); /*打印不相交时的cos(x)图形*/else printf( ); /*其它情况打印空格*/printf(n);return 0; *思考题如何实现sin(x)曲线与cos(x)曲线图形的同时显示。3.绘制圆在屏幕上用“*”画一个空心的圆 *问题分析与算法设计打印圆可利用图形的左右对称性。根据圆的方程:R*R=X*X+Y*Y可以算出圆上每一点行和列的对应关系。 *程序说明与注释#include#includeint main()double y;int x,m

      4、;for(y=10;y=-10;y)m=2.5*sqrt(100-y*y); /*计算行y对应的列坐标m,2.5是屏幕纵横比调节系数因为屏幕的行距大于列距,不进行调节显示出来的将是椭圆*/for(x=1;x30-m;x+) printf( ); /*图形左侧空白控制*/printf(*); /*圆的左侧*/for(;x30+m;x+) printf( ); /*图形的空心部分控制*/printf(*n); /*圆的右侧*/ return 0; *思考题实现函数y=x2的图形与圆的图形叠加显示 4.歌星大奖赛在歌星大奖赛中,有10个评委为参赛的选手打分,分数为1100分。选手最后得分为:去掉一个最高分和一个最低分后其余8个分数的平均值。请编写一个程序实现。*问题分析与算法设计这个问题的算法十分简单,但是要注意在程序中判断最大、最小值的变量是如何赋值的。*程序说明与注释#includeint main()int integer,i,max,min,sum;max=-32768; /*先假设当前的最大值max为C语言整型数的最小值*/min=32767; /*先假设当前的最小值min为C语言

      5、整型数的最大值*/sum=0; /*将求累加和变量的初值置为0*/for(i=1;imax)max=integer; /*通过比较筛选出其中的最高分*/if(integermin)min=integer; /*通过比较筛选出其中的最低分*/printf(Canceled max score:%dnCanceled min score:%dn,max,min);printf(Average score:%dn,(sum-max-min)/8); /*输出结果*/ *运行结果Input number1=90Input number2=91Input number3=93Input number4=94Input number5=90Input number6=99Input number7=97Input number8=92Input number9=91Input number10=95Canceled max score:99Canceled min score:90Average score:92 *思考题题目条件不变,但考虑同时对评委评分进行裁判,即在10个评委中找出最公平(即评

      6、分最接返平均分)和最不公平(即与平均分的差距最大)的评委,程序应该怎样实现?5.求最大数问555555的约数中最大的三位数是多少?*问题分析与算法设计根据约数的定义,对于一个整数N,除去1和它自身外,凡能整除N的数即为N的约数。因此,最简单的方法是用2到N-1之间的所有数去除N,即可求出N的全部约数。本题只要求取约数中最大的三位数,则其取值范围可限制在100到999之间。*程序说明与注释#includeint main()long i;int j;printf(Please input number:);scanf(%ld,&i);for(j=999;j=100;j)if(i%j=0)printf(The max factor with 3 digits in %ld is:%d,n,i,j);break;*运行结果输入:555555输出:The max factor with 3 digits in 555555 is:777 6.高次方数的尾数求13的13次方的最后三位数*问题分析与算法设计解本题最直接的方法是:将13累乘13次方截取最后三位即可。但是由于计算机所能表示的整数范围有

      7、限,用这种“正确”的算法不可能得到正确的结果。事实上,题目仅要求最后三位的值,完全没有必要求13的13次方的完整结果。研究乘法的规律发现:乘积的最后三位的值只与乘数和被乘数的后三位有关,与乘数和被乘数的高位无关。利用这一规律,可以大大简化程序。*程序说明与注释#includeint main()int i,x,y,last=1; /*变量last保存求X的Y次方过程中的部分乘积的后三位*/printf(Input X and Y(X*Y):);scanf(%d*%d,&x,&y);for(i=1;i=y;i+) /*X自乘Y次*/last=last*x%1000; /*将last乘X后对1000取模,即求积的后三位*/printf(The last 3 digits of %d*%d is:%dn,x,y,last%1000); /*打印结果*/*运行结果Input X and Y(X*Y):13*13The last 3 digits of 13*13 is:253Input X and Y(X*Y):13*20The last 3 digits of 13*20 is:8017.阶

      8、乘尾数零的个数100!的尾数有多少个零? *问题分析与算法设计可以设想:先求出100!的值,然后数一下末尾有多少个零。事实上,与上题一样,由于计算机所能表示的整数范围有限,这是不可能的。 为了解决这个问题,必须首先从数学上分析在100!结果值的末尾产生零的条件。不难看出:一个整数若含有一个因子5,则必然会在求100!时产生一个零。因此问题转化为求1到100这100个整数中包含了多少个因子5。若整数N能被25整除,则N包含2个因子5;若整数N能被5整除,则N包含1个因子5。*程序说明与注释#includeint main()int a,count =0;for(a=5;a=100;a+=5) /循环从5开始,以5的倍数为步长,考察整数+count; /若为5的倍数,计数器加1if(!(a%25) +count; /若为25的倍数,计数器再加1printf(The number of 0 in the end of 100! is: %d.n,count); /打印结果return 0; *运行结果The number of 0 inthe end of 100! is: 24. *问题进一步讨论 本题的求解程序是正确的,但是存在明显的缺点。程序中判断整数N包含多少个因子5的方法是与程序中的100有关的,若题目中的100改为1000,则就要修改程序中求因子5的数目的算法了。 *思考题 修改程序中求因子5的数目的算法,使程序可以求出任意N!的末尾有多少个零。 8.借书方案知多少小明有五本新书,要借给A,B,C三位小朋友,若每人每次只能借一本,则可以有多少种不同的借法?*问题分析与算法设计本问题实际上是一个排列问题,即求从5个中取3个进行排列的方法的总数。首先对五本书从1至5进行编号,然后使用穷举的方法。假设三个人分别借这五本书中的一本,当三个人所借的书的

      《c+c++语言经典、实用、趣味程序设计编程》由会员小**分享,可在线阅读,更多相关《c+c++语言经典、实用、趣味程序设计编程》请在金锄头文库上搜索。

      点击阅读更多内容
    最新标签
    信息化课堂中的合作学习结业作业七年级语文 发车时刻表 长途客运 入党志愿书填写模板精品 庆祝建党101周年多体裁诗歌朗诵素材汇编10篇唯一微庆祝 智能家居系统本科论文 心得感悟 雁楠中学 20230513224122 2022 公安主题党日 部编版四年级第三单元综合性学习课件 机关事务中心2022年全面依法治区工作总结及来年工作安排 入党积极分子自我推荐 世界水日ppt 关于构建更高水平的全民健身公共服务体系的意见 空气单元分析 哈里德课件 2022年乡村振兴驻村工作计划 空气教材分析 五年级下册科学教材分析 退役军人事务局季度工作总结 集装箱房合同 2021年财务报表 2022年继续教育公需课 2022年公需课 2022年日历每月一张 名词性从句在写作中的应用 局域网技术与局域网组建 施工网格 薪资体系 运维实施方案 硫酸安全技术 柔韧训练 既有居住建筑节能改造技术规程 建筑工地疫情防控 大型工程技术风险 磷酸二氢钾 2022年小学三年级语文下册教学总结例文 少儿美术-小花 2022年环保倡议书模板六篇 2022年监理辞职报告精选 2022年畅想未来记叙文精品 企业信息化建设与管理课程实验指导书范本 草房子读后感-第1篇 小数乘整数教学PPT课件人教版五年级数学上册 2022年教师个人工作计划范本-工作计划 国学小名士经典诵读电视大赛观后感诵读经典传承美德 医疗质量管理制度 2 2022年小学体育教师学期工作总结
    关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
    手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
    ©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.