二十八、 统计工龄
题目描述
给定公司N名员工的工龄,要求按工龄增序输出每个工龄段有多少员工。
输入格式:
输入首先给出正整数N(即员工总人数);随后给出N个整数,即每个员工的工龄,范围在[18, 65]。
输出格式:
按工龄的递增顺序输出每个工龄的员工个数,格式为:“工龄:人数”。每项占一行。如果人数为0则不输出该项。
测试输入 | 期待的输出 | 时间限制 | 内存限制 | 额外进程 | |
---|---|---|---|---|---|
测试用例 1 | 8 30 20 20 50 37 21 51 20 | 20:3 21:1 30:1 37:1 50:1 51:1 | 1秒 | 64M | 0 |
解题思路
很简单的排序题,数据范围小,数据量也很少,任取一种排序方法都能轻松AC。
这里重点补充一种方法:桶排序。这种排序方法并没有在教学大纲中,但认真读过一些算法书籍,或者接触过ACM的同学都应该知道这种排序方法。
桶排序是一种很快很简单的排序方法,在指定区间 [a,b] 内,为每一个数都建立一个 “桶”,对于输入的待排序数,属于哪个 “桶” 就把它装入哪对应的 “桶”中,最后按照 “桶” 的排列顺序依次将数输出即可。桶排序的思想很简单,是一种典型的用空间换时间的排序方法。其限制条件也很明显,对于空间开销不能太大,空间开销太大的排序不适合用桶排序。
如果题目中指定了数据的区间是【a,b】,我们在区间【a,b】上对每一个数都建立一个 “桶”。对于输入数 m(a<= m <=b),就将其装入编号为 m 的“桶”中;对于 n(a<= n <=b),就将 n 装入编号 n 的 “桶”中。等所有输入数都装填完毕,按照 a 到 b 的顺序,依次输出“桶”中元素即可。(因为填入的数值与 “桶” 的编号相同,“桶”中有几个元素,输出时就将 “桶” 的编号输出几次,遇到空 “桶” 则直接跳过。)
桶的存储结构也很简单,用简单的一维数组就可以。数组的长度就是“桶”的个数,数组的类型就是“桶”的最大容量。
比如 int a[100],“桶”的个数为 100,每只“桶”的容量是 32767。
上机代码
本题就是典型的指定区间,很适合使用桶排序来求解,题目不需要依次输出元素,仅输出元素的个数就可以了。
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;
//桶排序
int main()
{
int n, x, c[101];
memset(c, 0, sizeof(c));
scanf("%d", &n);
for (int i = 0; i < n; i++)
{
scanf("%d", &x);
c[x]++;
}
for (int i = 18; i <= 65; i++)
{
if(c[i]!=0)
printf("%d:%d\n", i, c[i]);
}
//system("pause");
return 0;
}