二十八、 统计工龄

二十八、 统计工龄

题目描述

给定公司N名员工的工龄,要求按工龄增序输出每个工龄段有多少员工。

输入格式:

输入首先给出正整数N(即员工总人数);随后给出N个整数,即每个员工的工龄,范围在[18, 65]。

输出格式:

按工龄的递增顺序输出每个工龄的员工个数,格式为:“工龄:人数”。每项占一行。如果人数为0则不输出该项。

测试输入期待的输出时间限制内存限制额外进程
测试用例 18
30 20 20 50 37 21 51 20
20:3
21:1
30:1
37:1
50:1
51:1
1秒64M0

解题思路

很简单的排序题,数据范围小,数据量也很少,任取一种排序方法都能轻松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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值