第一题
题目描述
(1)定义两个一维数组x,y,不超过50个元素。
(2)从键盘输入k个整数到数组x中。
(3)计算x中数据的平均值ave及大于平均值的元素个数n并输出。
(4)将数组x中数据复制到数组y中,重复的数据只存储一次,最后输出y中的数据。
输入:输入两行,第一行为输入的数据个数,第二行若干整数,每个整数后面有一个空格用于分隔;
输出:第一行若干整数,每个整数后面有一个空格,最后一个空格后换行;第二行若干整数,每个整数后面有一个空格,最后一个空格后不需要换行;
源代码
#include<iostream>
using namespace std;
int list1[50], list2[50];
float ave=0;
int sum=0;
int more=0;
int main()
{
int n=0;
cin>>n;
for (int i=0; i<n; i++)
{
int temp;
cin>>temp;
list1[i]=temp;
sum+=temp;
}
ave=1.0*sum/n;
cout<<ave<<" ";
for (int j=0; j<n; j++)
{
if (list1[j]>ave)
{
more++;
}
}
cout<<more<<endl;
for (int p1=0,p2=0; p1<n; p1++,p2++)
{
bool flag=1;
for (int k=0; k<p1; k++)
{
if (list1[p1]==list1[k])
{
flag=0;
break;
}
}
if (flag)
{
list2[p2]=list1[p1];
cout<<list2[p2]<<" ";
}
}
}
运行结果
第二题
题目描述
有12人围坐成一圈玩报数游戏,从1号人员开始顺时针报数,报到k的人员被淘汰出局;接着仍沿顺时针方向从被淘汰出局者的下一人员又重新从1 开始报数,报到k的人被淘汰;如此继续,直到最后只剩下一个人时停止。请编写程序输出最后所剩那个人的编号。
注意:(1)假设参加游戏的人的编号沿顺时针方向依次为1到12,可以使用数组来存放各数据;
(2)k>1,由用户通过cin输入指定。输入一个整数,代表报数值;
输出一个整数,即最后剩下的人的编号;
源代码
#include<iostream>
using namespace std;
int main()
{
int s[12];
int i,j,k;
for (i=1;i<=12;i++)
{
s[i]=i;
}
cin >> k;
int n=12;
int start=1;
while (n > 1)
{
j=k+start-1;
while (j >= n) j=j % n;
if (j == 0) j=n;
start=j;
for (i=start+1;i<=12;i++)
s[i-1]=s[i];
n--;
}
cout << s[1] << endl;
return 0;
}
运行截图
第三题
题目描述
小宗想知道两个日期之间所间隔的天数,他希望有一个日期计算器,输入两个日期后能够自动计算之间的天数。要求:设计相应的函数完成天数的计算,在主函数中验证正确性。
输入:按照年月日的顺序输入两个日期,年月日之间用一个空格分隔;
输出:输出两个日期之间的天数,即一个整数,整数后不需要换行;
源代码
#include<iostream>
using namespace std;
int m[12] = {31,28,31,30,31,30,31,31,30,31,30,31};
bool isLeapYear(int year)
{
return ((year%4==0 && year%100!=0) || year%400==0);
}
int getDays(int year, int month, int day)
{
if(isLeapYear(year))
m[1]++;
int sum = 0;
for(int i = 1;i < year;i++)
{
sum += 365;
if(isLeapYear(i))
sum ++;
}
for(int i = 1;i < month;i++)
{
sum += m[i-1];
}
sum += day;
return sum;
}
int dayDis (int y1, int m1, int d1,
int y2, int m2, int d2)
{
return getDays(y2, m2, d2) - getDays(y1, m1, d1);
}
int main(void)
{
int y1,m1,d1;
int y2,m2,d2;
cin>>y1>>m1>>d1>>y2>>m2>>d2;
cout<<dayDis(y1,m1,d1,y2,m2,d2);
return 0;
}
运行截图
第四题
题目描述
对于整型数组a[10]和b[10],编制程序完成下列任务:
(1)由用户从键盘为两个数组输入值;
(2)求出两个数组的最大值和最小值;
(3)把数组a和b中的整数分别从小到大和从大到小排序;
(4)把两个有序的数组a和b组成一个长度为20的有序数组c[20],使数组c的顺序为从小到大。
输入:两行整数,每行10个,第一行是数组a里的数组,第二行是数组b里的数值;
输出:五行,第一行有两个整数,分别是数组a的最大值和最小值,两个整数之间用一个空格分隔;第二行有两个整数,分别是数组b的最大值和最小值,两个整数之间用一个空格分隔;第三行按照从小到大的顺序输出数组a里的数值,每个数字后面有一个空格,最后一个数字后面也有空格;第四行按照从大到小的顺序输出数组b里的数值,每个数字后面有一个空格,最后一个数字后面也有空格;第五行按照从小到大的顺序输出合并后数组c里的数值,每个数字后面有一个空格,最后一个数字后面也有空格。
源代码
#include<iostream>
using namespace std;
int a[10];
int b[10];
int c[20];
int max(int n[])
{
int M=n[0];
for (int i=0; i<10; i++)
{
if (n[i]>M) M=n[i];
}
return M;
}
int min(int n[])
{
int m=n[0];
for (int i=0; i<10; i++)
{
if (n[i]<m) m=n[i];
}
return m;
}
void sort(int n[])
{
for (int i=0; i<9; i++)
{
for (int j=0; j<9; j++)
{
if (n[j]>n[j+1])
{
int temp=n[j];
n[j]=n[j+1];
n[j+1]=temp;
}
}
}
}
void mix(int m[], int n[])
{
int p1=0;
int p2=0;
int p3=0;
while(p1<=9 && p2<=9)
{
if (m[p1]<n[p2])
{
c[p3]=m[p1];
p1++; p3++;
}
else
{
c[p3]=n[p2];
p2++; p3++;
}
}
if (p1==10)
{
for (; p3<20; p2++, p3++) c[p3]=n[p2];
}
else
{
for (; p3<20; p1++, p3++) c[p3]=m[p1];
}
}
int main()
{
for (int i=0; i<10; i++) cin>>a[i];
for (int i=0; i<10; i++) cin>>b[i];
cout<<max(a)<<" "<<min(a)<<endl;
cout<<max(b)<<" "<<min(b)<<endl;
sort(a);
for (int i=0; i<10; i++) cout<<a[i]<<" ";
cout<<endl;
sort(b);
for (int i=9; i>=0; i--) cout<<b[i]<<" ";
cout<<endl;
mix(a,b);
for (int i=0; i<20; i++) cout<<c[i]<<" ";
cout<<endl;
}
运行截图
第五题
题目描述
利用cin.getline()函数从键盘录入一句英文,其中每个单词之间用一个空格隔开,最后用'.'结束。统计该句话中单词的个数,并依次输出每个单词。输出个数后换行,输出每个单词后也换行。注意:在本平台下,cin.getline()函数的使用方式如下:
char s[50];
cin.getline(s,50); //最多存储49个字符
输入一句英文,其中每个单词之间用一个空格隔开,最后一个单词后面用英文的'.'作为结束;输出每个单词后换行,最后一行输出单词的数量。
源代码
#include<iostream>
using namespace std;
int main()
{
int i,num=0;
char s[50];
cin.getline(s,50);
while(1)
{
if(s[i]!=' ' &&s[i]!='.')
cout<<s[i];
else
{
num++;
cout<<endl;
}
if(s[i]=='.')
break;
i++;
}
cout<<num;
}