实践题1
【问题描述】编程序,实现如下功能:
(1)定义两个一维数组x,y,不超过50个元素。
(2)从键盘输入k个整数到数组x中。
(3)计算x中数据的平均值ave及大于平均值的元素个数n并输出。
(4)将数组x中数据复制到数组y中,重复的数据只存储一次,最后输出y中的数据。
【输入形式】输入两行,第一行为输入的数据个数,第二行若干整数,每个整数后面有一个空格用于分隔;
【输出形式】第一行若干整数,每个整数后面有一个空格,最后一个空格后换行;第二行若干整数,每个整数后面有一个空格,最后一个空格后不需要换行;
【样例输入】
6
6 3 4 3 2 9
【样例输出】
4.5 2
6 3 4 2 9
#include<iostream>
#include<iomanip>
#include<algorithm>
using namespace std;
int main()
{
// freopen("1.in","r",stdin);
// freopen("1.out","w",stdout);
int x[51];
x[0]=0;
int k,i,j,cnt=0;
float ave;
cin >> k;
for(i=1;i<=k;i++)
{
cin >> x[i];
x[0]+=x[i];
}
ave=(float)x[0]/k;
cout << ave << " ";
for(i=1;i<=k;i++) if(x[i]>ave)cnt++;
cout << cnt << endl;
for(i=1;i<=k;i++)
{
int flag=1;
for(j=1;j<i;j++) if(x[j]==x[i]) flag=0;
if(flag) cout << x[i] << " "; else continue;
}
// fclose(stdin);
// fclose(stdout);
return 0;
}
实践题2
【问题描述】有 12 人围坐成一圈玩报数游戏,从1号人员开始顺时针报数,报到k的人员被淘汰出局;接着仍沿顺时针方向从被淘汰出局者的下一人员又重新从 1 开始报数,报到 k的人被淘汰;如此继续,直到最后只剩下一个人时停止。请编写程序输出最后所剩那个人的编号。
注意:
(1)假设参加游戏的人的编号沿顺时针方向依次为 1 到 12,可以使用数组来存放各数据;
(2)k>1,由用户通过 cin 输入指定。
【输入形式】输入一个整数,代表报数值;
【输出形式】输出一个整数,即最后剩下的人的编号;
【样例输入】3
【样例输出】10
#include<iostream>
#include<iomanip>
#include<algorithm>
using namespace std;
const int MAX = 12;
int main(