每日一报

链接:https://ac.nowcoder.com/acm/problem/205273 来源:牛客网

时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K,其他语言1048576K 64bit IO Format:
%lld

题目描述

链接:https://ac.nowcoder.com/acm/problem/205273
来源:牛客网

为了预防新型冠状病毒的侵袭,学校组织学生进行每日一报——自 2020 年 1 月 30 日 起至今,每位同学都必须上报自己的身体状况。为了简化问题,我们规定每日一报仅包含以下信息:

  • 报送日期:固定 8 位十进制数,格式为 YYYYMMDD ,如 20200312 代表 2020 年 3 月 12 日;
  • 学号:固定 8 位十进制数,不必追溯其具体含义,如 17122490;
  • 体温:保留一位小数的浮点数,单位为摄氏度,介于 35.0 至 45.0 之间,如 37.1。

作为学校数据库负责人,Lemon 需要对体温异常(不低于 38.0 摄氏度)的报送消息进行整理后向上级上报备案。具体整理规则如下:将报送日期作为第一关键字降序,将体温作为第二关键字降序,将学号作为第三关键字升序排序。即在整理完成后,任意两条报送记录都有如下关系:

  • 报送日期不一致的,则日期较近的在上,日期较久远的在下;

  • 报送日期一致体温不一致的,则体温高的在上,体温低的在下;

  • 报送日期和体温都一致的,则学号小的在上,学号大的在下。

你能帮助 Lemon 完成这个任务吗?

输入描述:

第一行包含一个整数 n (1≤n≤1001 \leq n \leq 1001≤n≤100),表示需要处理的报送记录。 接下来 n
行,每行代表一条报送记录。 每一条记录包含两个整数和一个浮点数,中间空格分隔,分别表示报送日期、学号和体温,格式如题目描述中所述
输入保证所有的报送日期是 2020 年 1 月 30 日至今(2020 年 4 月 18
日)的合法日期,同一个学号不会在同一天进行多次报送。

示例1

输入

5
20200229 17122490 37.0
20200301 17122490 38.4
20200229 17122640 39.0
20200301 17122640 38.4
20200301 16122138 38.1

输出

4
20200301 17122490 38.4
20200301 17122640 38.4
20200301 16122138 38.1
20200229 17122640 39.0

代码1:

#include<iostream>
#include<algorithm>
#include<iomanip>
using namespace std;
struct submit {
	long long int a;
	long long int b;
	double c;
};
int main()
{
	submit s[100],p[100];
	int m;
	cin >> m;
	for (int i = 0;i < m;i++)
	{
		cin >> p[i].a >> p[i].b >> p[i].c;
	}
	int d = 0;
	for (int i = 0;i < m;i++)
	{
		if (p[i].c>=38)
		{
			s[d] = p[i];
			d++;
		}
	}
	for (int i = 0;i < d - 1;i++)
	{
		for (int j = i + 1;j < d;j++)
		{
				submit t;
				if (s[i].a != s[j].a)
				{
					if (s[i].a < s[j].a)
					{
						t = s[i];
						s[i] = s[j];
						s[j] = t;
					}
				}
				else
				{
					if (s[i].c != s[j].c)
					{
						if (s[i].c < s[j].c)
						{
							t = s[i];
							s[i] = s[j];
							s[j] = t;
						}
					}
					else
					{
						if (s[i].b > s[j].b)
						{
							t = s[i];
							s[i] = s[j];
							s[j] = t;
						}
					}
				}
			}

		}
	
	cout << d << endl;
	for (int i = 0;i < d;i++)
	{
		cout << s[i].a << " " << s[i].b << " ";
		cout<<fixed<<setprecision(1) << s[i].c << endl;
	}
}

代码2:

#include<iostream>
#include<algorithm>
#include<iomanip>
using namespace std;
struct submit {
	long long int a;
	long long int b;
	double c;
};
bool camp(submit p, submit q)
{
	if (p.a == q.a)
	{
		if (p.c == q.c)
		{
			return p.b < q.b;
		}
		else
		{
			return p.c > q.c;
		}
	}
	else return (p.a > q.a);
}
int main()
{
	submit s[100], p[100];
	int m;
	cin >> m;
	int d = 0;
	for (int i = 0;i < m;i++)
	{
		cin >> p[i].a >> p[i].b >> p[i].c;
		if (p[i].c >= 38)
		{
			s[d] = p[i];
			d++;
		}
	}
	sort(s, s +d, camp);

	cout << d << endl;
	for (int i = 0;i < d;i++)
	{
		cout << s[i].a << " " << s[i].b << " ";
		cout << fixed << setprecision(1) << s[i].c << endl;
	}
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章