二十八、 统计工龄
二十八、 统计工龄
文章目录
- 二十八、 统计工龄
- 题目描述
- 解题思路
- 上机代码
题目描述
给定公司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; }