欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

二十八、 统计工龄

发布时间:2025/3/21 编程问答 44 豆豆
生活随笔 收集整理的这篇文章主要介绍了 二十八、 统计工龄 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

二十八、 统计工龄

文章目录

  • 二十八、 统计工龄
    • 题目描述
    • 解题思路
    • 上机代码

题目描述

给定公司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; }

总结

以上是生活随笔为你收集整理的二十八、 统计工龄的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。