欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    C语言歌星大奖赛为参赛的选手打分.docx

    • 资源ID:3060766       资源大小:38.19KB        全文页数:4页
    • 资源格式: DOCX        下载积分:6.99金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要6.99金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    C语言歌星大奖赛为参赛的选手打分.docx

    C语言 歌星大奖赛为参赛的选手打分C语言歌星大奖赛为参赛的选手打分 在歌星大奖赛中,有 10 个评委为参赛的选手打分,分数为 1100 分。选手最后得分为:去掉 一个最高分和一个最低分后其余 8 个分数的平均值。请编写一个程序实现。 *问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 这个问题的算法十分简单,但是要注意在程序中判断最大、最小值的变量是如何赋值的。 *程序说明与注释 #include<stdio.h> int main int integer,i,max,min,sum; max=-32768; /*先假设当前的最大值 max 为 C 语言整型数的最小值*/ min=32767; /*先假设当前的最小值 min 为 C 语言整型数的最大值*/ sum=0; /*将求累加和变量的初值置为 0*/ for(i=1;i<=10;i+) printf("Input number %d=",i); scanf("%d",&integer); /*输入评委的评分*/ sum+=integer; /*计算总分*/ if(integer>max)max=integer; /*通过比较筛选出其中的最高分*/ if(integer<min)min=integer; /*通过比较筛选出其中的最低分*/ printf("Canceled max score:%dnCanceled min score:%dn",max,min); printf("Average score:%dn",(sum-max-min)/8); /*输出结果*/ *运行结果 运行结果 运行结果 运行结果 Input number1=90 Input number2=91 Input number3=93 Input number4=94 Input number5=90 Input number6=99 Input number7=97 Input number8=92 Input number9=91 Input number10=95 Canceled max score:99 Canceled min score:90 Average score:92 案例七: 问 555555 的约数中最大的三位数是多少? *问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 根据约数的定义,对于一个整数 N,除去 1 和它自身外,凡能整除 N 的数即为 N 的约数。因此, 最简单的方法是用 2 到 N-1 之间的所有数去除 N,即可求出 N 的全部约数。本题只要求取约数 中最大的三位数,则其取值范围可限制在 100 到 999 之间。 *程序说明与注释 #include<stdio.h> int 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 案例八: 求 13 的 13 次方的最后三位数 *问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 解本题最直接的方法是:将 13 累乘 13 次方截取最后三位即可。 但是由于计算机所能表示的整数范围有限, 用这种“正确”的算法不可能得到正确的结果。 事实上, 题目仅要求最后三位的值,完全没有必要求 13 的 13 次方的完整结果。 研究乘法的规律发现: 乘积的最后三位的值只与乘数和被乘数的后三位有关, 与乘数和被乘数的 高位无关。利用这一规律,可以大大简化程序。 *程序说明与注释 #include<stdio.h> int 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*13 The last 3 digits of 13*13 is:253 Input X and Y(X*Y):13*20 The last 3 digits of 13*20 is:801 案例九: 100!的尾数有多少个零? *问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 问题分析与算法设计 可以设想:先求出 100!的值,然后数一下末尾有多少个零。事实上,与上题一样,由于计 算机所能表示的整数范围有限,这是不可能的。 为了解决这个问题,必须首先从数学上分析在 100!结果值的末尾产生零的条件。不难看 出: 一个整数若含有一个因子 5, 则必然会在求 100!时产生一个零。 因此问题转化为求 1 到 100 这 100 个整数中包含了多少个因子 5。若整数 N 能被 25 整除,则 N 包含 2 个因子 5;若整数 N 能被 5 整除,则 N 包含 1 个因子 5。 *程序说明与注释 #include<stdio.h> int main int a,count =0; for(a=5;a<=100;a+=5) /循环从 5 开始,以 5 的倍数为步长,考察整数 +count; /若为 5 的倍数,计数器加 1 if(!(a%25) +count; /若为 25 的倍数,计数器再加 1 printf("The number of 0 in the end of 100! is: %d.n",count); /打印结果 return 0; *运行结果运行结果运行结果运行结果 The number of 0 in the end of 100! is: 24. *问题进一步讨论

    注意事项

    本文(C语言歌星大奖赛为参赛的选手打分.docx)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开