数组的复制 | 围圈报数问题 | 求日期间隔(考虑闰年) | 统计单词的个数

实践题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()
{
// 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

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()
{
// freopen("1.in","r",stdin);
// freopen("1.out","w",stdout);
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++) cout << a[i] << " ";
// cout << endl;
for(int i=1;i<=MAX;i++)
{
if(a[i]==0) cout << i;
}
// fclose(stdin);
// fclose(stdout);
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()
{
// freopen("1.in","r",stdin);
// freopen("1.out","w",stdout);
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;
// fclose(stdin);
// fclose(stdout);
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()
{
// freopen("1.in","r",stdin);
// freopen("1.out","w",stdout);
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] << " ";
// fclose(stdin);
// fclose(stdout);
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()
{
// freopen("1.in","r",stdin);
// freopen("1.out","w",stdout);
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;
// fclose(stdin);
// fclose(stdout);
return 0;
}

 评论

载入天数...载入时分秒...