当前位置:   article > 正文

C/C++语言经典、实用、趣味程序设计编程百例精解_c++趣味编程100例

c++趣味编程100例

4. 歌星大赛

题目描述:
歌星大奖赛中,有10个评委为参赛的选手打分,分数为1~100分。选手最后得分为:去掉一个最高分和一个最低分后其余8个分数的平均值.
样例输入: 
90 91 93 94 90 99 97 92 91 95 
样例输出: 
The max is 99 
The min is 90 
Average score is 92
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
*思考题
题目条件不变,但考虑同时对评委评分进行裁判,即在10个评委中找出最公平(即评分最接返平均分)和最不公平(即与平均分的差距最大)的评委。
  • 1
  • 2
#include <iostream>
#include <math.h>
using namespace std;
#define MAx 10
int main() {
    int num[MAx];
    for(int i=0 ;i<MAx ; i++)
		cin>>num[i];
	int max=num[0];
	int min=num[0];
	int s=0;
    for(int i=0 ;i<MAx ; i++) {
    	s+=num[i];
		if(num[i]>max)
			max=num[i];
		if(num[i]<min)
			min=num[i];
	}
	int aver=(s-min-max)/8;
	/*    错误
	for(int i=0 ; i<10 ; i++)
		if(num[i]!=max && num[i]!=min)  
			s+=num[i];
	*/
	cout<<"The max is "<<max<<endl;
	cout<<"The min is "<<min<<endl;
	cout<<"Average score is "<<aver<<endl;
	/*int a[MAx];            //思考题
	int amax=abs(num[0]-aver);  //与平均数的差值最大
	int amin=abs(num[0]-aver);
	int j=0,k=0;
    for(int i=0 ;i<MAx ; i++) {
		a[i]=abs(num[i]-aver);
  		if(a[i]>amax) {
			amax=a[i];
			k=i;
		}
		if(a[i]<amin) {
			amin=a[i];
			j=i;
		}
	}
	cout<<"fairest is "<<num[j]<<endl;
	cout<<"disfairest is "<<num[k]; */
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47

分析:
1.在数组中找出最大和最小值,最快的方法就是:将整型的最大最小值分别赋值给max(二字节:32767 四字节:2147483647),min(二字节:-32768 四字节:-2147483648)由于数字长难记,我们可以将数组的任何一个元素赋值给max,min;然后将其分别与数组中的各个元素比较,最终找到最大最小值
2.去掉一个最高分和一个最低分后其余8个分数的平均值:当元素中有多个最大最小最小值时,只减去一个最大最小值,然后除以8;
3.同时求最小最大值时,可以同时在一个循环里求,互不影响。

有关求最大最小值的拓展

实验7-1-2 求最大值及其下标

输入格式:
输入在第一行中给出一个正整数n(1<n≤10)。第二行输入n个整数,用空格分开。

输出格式:
在一行中输出最大值及最大值的最小下标,中间用一个空格分开。

输入样例:
6
2 8 10 1 9 10       
输出样例:
10 2     (结尾无空行)

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
#include <stdio.h>
int main()
{   int n;
	scanf("%d",&n);
	int num[10];
	for(int i=0 ;i<n ; i++)
		scanf("%d",&num[i]);
	int max=num[0];
	int j=0;
	for(int i=0 ;i<n ; i++)
		if(max<num[i]) {  //没有等号
			max=num[i];
			j=i;
		}
	printf("%d %d",max,j);
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

实验7-1-6 求一批整数中出现最多的个位数字

给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。
例如给定3个整数123423453456,其中出现最多次数的数字是34,均出现了3次。
输入格式:
输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负数,数字间以空格分隔。

输出格式:
在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n1、n2、……为出现次数最多的个位数字,按从小到大的顺序排列。
数字间以空格分隔,但末尾不得有多余空格。
输入样例:
3
1234 2345 3456
(结尾无空行)
输出样例:
3: 3 4
(结尾无空行)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
#include <iostream>
using namespace std;
int main() {
	int n;
	cin>>n;
	int num[n];
	int a[10]={0};
	for(int i=0 ; i<n ; i++) {
		cin>>num[i];
		int b=num[i];
		while(b) {
			a[b%10]++;
			b/=10;
		}

	}
	int max=1,j=0;
	for(int i=0; i<10 ; i++) {
		if(a[i]!=0)
			if(max<=a[i]) {  //有等号
				max=a[i];
				j=i;
			}
	}
	cout<<max<<":";
	for(int i=0 ; i<=j ; i++)
		if(max == a[i] )
			cout<<" "<<i;
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30

分析:从上面两道题可以看出if(max<=a[i])if(max<a[i])处理有多个最大值(最小值)的区别:
有等号时最大值或最小值对应的下标是最大下标,而没有等号时最大值或最小值对应的下标是最小下标

5. 555555的约数中最大的三位数是多少

题目描述:
问555555的约数中最大的三位数是多少?
  • 1
  • 2
#include <iostream>
#include <math.h>
using namespace std;
#define MAx 10
int main() {
	int num;
	cin>>num;
	int j=0;
	int a[10000];
	int max=-1; //约数始终大于0
	for(int i=100 ; i<1000 ; i++,j++) {
		if(num%i == 0)
			a[j]=i;  //将约数赋给a数组
		if(a[j]>max)
			max=a[j];
	}
	cout<<"The max factor with 3 digits in "<<num<<" is "<<max;
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

6.高次方数的尾数

题目描述:
求m的n次方的最后三位数
样例1输入:
13 13
样例1输出:
253
样例2输入:
13 20
样例2输出:
801
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
在这里插入代码片
  • 1

7.阶乘尾数零的个数

样例输入:
100
样例输出:
24
  • 1
  • 2
  • 3
  • 4
在这里插入代码片
  • 1
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/427632
推荐阅读
相关标签
  

闽ICP备14008679号