版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、C 语言歌星大奖赛为参赛的选手打分在歌星大奖赛中,有10个评委为参赛的选手打分,分数为 1100分。选手最后得分为:去掉一个最高分和一个最低分后其余8 个分数的平均值。请编写一个程序实现。* 问题分析与算法设计问题分析与算法设计问题分析与算法设计问题分析与算法设计这个问题的算法十分简单,但是要注意在程序中判断最大、最小值的变量是如何赋值的。* 程序说明与注释#include<stdio.h>int main()int integer,i,max,min,sum;max=-32768;/*先假设当前的最大值 max为C语言整型数的最小值*/min=32767; /*先假设当前的最小值
2、 min为C语言整型数的最大值*/* um=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 sc
3、ore:%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 ma
4、x score:99Canceled min score:90Average score:92案例七:问 555555 的约数中最大的三位数是多少?* 问题分析与算法设计问题分析与算法设计问题分析与算法设计问题分析与算法设计根据约数的定义,对于一个整数N,除去1和它自身外,凡能整除N的数即为 N 的约数。因此,最简单的方法是用2到N-1之间的所有数去除N,即可求出N的全部约 数。本题只要求取约数中最大的三位数,则其取值范围可限制在100 到 999 之间。* 程序说明与注释#include<stdio.h>int main()long i;int j;printf("Pl
5、ease input number:");scanf("%ld",&i);for(j=999;j>=100;j Bif(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次方的最后三位数* 问题分析与算法设计问题分析与算法设计问题分析与算法设计问题分析与算法设计解本
6、题最直接的方法是:将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):"
7、;);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
8、 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 numb
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 宿舍楼房出租合同
- 商标转让合同样本
- 房地产交易经纪合同
- 股份质押合同
- 个人抵押借款合同
- 商品房装修工程合同范本
- STEAM理念下初中数学项目式学习的设计研究
- 面向小行星探测的着陆器附着钻进锚固力学特性研究
- 2025年安阳道路货运驾驶员从业资格证考试题库完整
- 高速光通信系统中信号识别方法研究
- 《教科版》二年级科学下册全册课件(完整版)
- (2024年)《处方管理办法》培训课件
- 人工智能在化工生产安全中的应用
- 2023年6月浙江高考政治试卷真题解读及答案解析(课件)
- 销售部廉政培训课件
- 三年级计算题三位数乘一位数练习300题带答案
- 商务服务业的市场细分和定位策略
- 财政学论文我国财政支出存在的问题及改革建议
- 2022年湖南高速铁路职业技术学院单招数学模拟试题及答案解析
- 小学生必备古诗
- 人教版英语八年级上册单词默写表
评论
0/150
提交评论