数组的复制 | 围圈报数问题 | 求日期间隔(考虑闰年) | 统计单词的个数
实践题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
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
| #include<iostream> #include<iomanip> #include<algorithm> using namespace std; int main() {
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; }
return 0; }
|
实践题2
【问题描述】有 12 人围坐成一圈玩报数游戏,从1号人员开始顺时针报数,报到k的人员被淘汰出局;接着仍沿顺时针方向从被淘汰出局者的下一人员又重新从 1 开始报数,报到 k的人被淘汰;如此继续,直到最后只剩下一个人时停止。请编写程序输出最后所剩那个人的编号。
注意:
(1)假设参加游戏的人的编号沿顺时针方向依次为 1 到 12,可以使用数组来存放各数据;
(2)k>1,由用户通过 cin 输入指定。
【输入形式】输入一个整数,代表报数值;
【输出形式】输出一个整数,即最后剩下的人的编号;
【样例输入】3
【样例输出】10
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
| #include<iostream> #include<iomanip> #include<algorithm> using namespace std; const int MAX = 12; int main() {
int k,a[MAX+1]={0}; cin >> k; int now=1; for(int i=1;i<=MAX-1;i++) { for(int j=1;j<=k;) { if(now>MAX) now-=MAX; if(j==k&&a[now]!=1)break; if(j==k&&a[now]==1) { now++; continue; } if(a[now]==0) { j++; now++; continue; } if(a[now]==1)now++; } a[now]=1; now++; }
for(int i=1;i<=MAX;i++) { if(a[i]==0) cout << i; }
return 0; }
|
实践题3
【问题描述】小宗想知道两个日期之间所间隔的天数,他希望有一个日期计算器,输入两个日期后能够自动计算之间的天数。要求:设计相应的函数完成天数的计算,在主函数中验证正确性。
【输入形式】按照年月日的顺序输入两个日期,年月日之间用一个空格分隔;
【输出形式】输出两个日期之间的天数,即一个整数,整数后不需要换行;
【样例输入】
2016 3 6
2017 1 1
【样例输出】301
【样例说明】输入输出中不要有中文提示,最后的输出不需要换行。
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
| #include<iostream> #include<iomanip> #include<algorithm> using namespace std; int is_run(int year) { if(year%4==0&&year%100!=0) return 1; if(year%100==0&&year%400==0) return 1; return 0; }
int main() {
int g[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}; int nian1,yue1,ri1; int nian2,yue2,ri2; int ans=0; cin >> nian1 >> yue1 >> ri1; cin >> nian2 >> yue2 >> ri2; for(int i=nian1;i<nian2;i++) { if(is_run(i)) ans+=366; else ans+=365; } if(is_run(nian2))g[2]=29; for(int i=0;i<yue2;i++) ans+=g[i]; ans+=ri2; g[2]=28; if(is_run(nian1))g[2]=29; for(int i=0;i<yue1;i++) ans-=g[i]; ans-=ri1; cout << ans;
return 0; }
|
实践题4
【问题描述】对于整型数组a[10]和b[10],编制程序完成下列任务:
(1)由用户从键盘为两个数组输入值;
(2)求出两个数组的最大值和最小值;
(3)把数组a和b中的整数分别从小到大和从大到小排序;
(4)把两个有序的数组a和b组成一个长度为20的有序数组c[20],使数组c的顺序为从小到大。
【输入形式】输入两行整数,每行10个,第一行是数组a里的数组,第二行是数组b里的数值;
【输出形式】输出五行,第一行有两个整数,分别是数组a的最大值和最小值,两个整数之间用一个空格分隔;第二行有两个整数,分别是数组b的最大值和最小值,两个整数之间用一个空格分隔;第三行按照从小到大的顺序输出数组a里的数值,每个数字后面有一个空格,最后一个数字后面也有空格;第四行按照从大到小的顺序输出数组b里的数值,每个数字后面有一个空格,最后一个数字后面也有空格;第五行按照从小到大的顺序输出合并后数组c里的数值,每个数字后面有一个空格,最后一个数字后面也有空格。
【样例输入】
2 5 9 1 3 4 0 6 7 8
10 5 25 9 6 3 7 1 2 13
【样例输出】
9 0
25 1
0 1 2 3 4 5 6 7 8 9
25 13 10 9 7 6 5 3 2 1
0 1 1 2 2 3 3 4 5 5 6 6 7 7 8 9 9 10 13 25
【样例说明】请严格按照输入输出形式的规定。
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 48 49 50 51 52 53 54
| #include<iostream> using namespace std; void sort(int g[],int n) { int temp; for(int i=1;i<n;i++) { int min=g[i]; int min_where=i; for(int j=i+1;j<=n;j++) { if(min>g[j]) { min=g[j]; min_where=j; } } temp = g[i]; g[i] = g[min_where]; g[min_where]=temp; } } int main() {
int a[11],b[11],c[21]; int amax=0,amin=0x7fffffff,bmax=0,bmin=0x7fffffff; for(int i=1;i<=10;i++) { cin >> a[i]; if(a[i]>amax)amax=a[i]; if(a[i]<amin)amin=a[i]; } for(int i=1;i<=10;i++) { cin >> b[i]; if(b[i]>bmax)bmax=b[i]; if(b[i]<bmin)bmin=b[i]; } cout << amax << " " << amin << endl; cout << bmax << " " << bmin << endl; sort(a,10); sort(b,10); for(int i=1;i<=10;i++) cout << a[i] << " ";cout << endl; for(int i=10;i>=1;i--) cout << b[i] << " ";cout << endl; for(int i=1;i<=10;i++) c[i]=a[i]; for(int i=11;i<=20;i++) c[i]=b[i-10]; sort(c,20); for(int i=1;i<=20;i++) cout << c[i] << " ";
return 0; }
|
实践题5
【问题描述】利用cin.getline()函数从键盘录入一句英文,其中每个单词之间用一个空格隔开,最后用’.’结束。统计该句话中单词的个数,并依次输出每个单词。输出个数后换行,输出每个单词后也换行。注意:在本平台下,cin.getline()函数的使用方式如下:
char s[50];
cin.getline(s,50); //最多存储49个字符
【输入形式】输入一句英文,其中每个单词之间用一个空格隔开,最后一个单词后面用英文的’.’作为结束;
【输出形式】输出每个单词后换行,最后一行输出单词的数量。
【样例输入】I like juice.
【样例输出】
I
like
juice
3
【样例说明】请严格按照规定的格式输入和输出。
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
| #include<iostream> using namespace std; int main() {
char s[50]; int cnt=0; cin.getline(s,50); for(int i=0;s[i]!='\0';i++) { if(s[i]==' '||s[i]=='.') { cout << endl; cnt++; } else { cout << s[i]; } } cout << cnt;
return 0; }
|