【C++】实验四 数组


实践题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()
{
//	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
【样例说明】输入输出中不要有中文提示,最后的输出不需要换行。

#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
【样例说明】请严格按照输入输出形式的规定。

#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
【样例说明】请严格按照规定的格式输入和输出。

#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;
}


发布了38 篇原创文章 · 获赞 4 · 访问量 1649

猜你喜欢

转载自blog.csdn.net/qq_15989473/article/details/103229975
今日推荐