题意:一个公司有很多员工,也有主管。每天员工和主管都需要签到,但主管可以用签到机确认有多少人上班,也可以按员工ID顺序或签到顺序打印出上班的员工,还可以找出倒数第n个上班的员工是谁。
要求:
用面向对象的方法分析和实现;
所有操作的时间消耗和空间消耗越低越好,其中排序算法的时间复杂度不超过O(nlogn),极端情况下也不可以退化为n^2
思路:员工是基类,主管是派生类。选用排序方式:堆排序priority_queue,时间复杂度O(nlogn)
#include <iostream>
#include <string>
#include <vector>
#include <queue>
using std::cout;
using std::endl;
using std::string;
using std::vector;
using std::pair;
using std::priority_queue;
using std::endl;
using std::string;
using std::vector;
using std::pair;
using std::priority_queue;
class Staff
{
public:
Staff() = default; //生成一个默认的构造函数
{
public:
Staff() = default; //生成一个默认的构造函数
Staff(vector<std::pair<int, int>> staff)&nbs

本文介绍了一个使用C++面向对象编程实现的公司员工签到系统。该系统中,员工是基类,主管是派生类。主管具备签到、按ID或签到顺序打印员工以及查找倒数第n个签到员工的功能。为了优化性能,签到排序采用了堆排序(priority_queue),确保时间复杂度不超过O(nlogn),避免极端情况下的退化。
最低0.47元/天 解锁文章
932

被折叠的 条评论
为什么被折叠?



