news 2026/4/19 1:44:16

C++ STL案例2——员工分组

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++ STL案例2——员工分组

写在前面:⭐如果本篇博文对你有帮助,那就 点赞 + 关注 + 收藏 一下吧!

1.案例描述

●公司今天招聘了10个员工(ABCDEFGHIJ),10名员工进入公司之后,需要指派员工在那个部门工作
●员工信息有:姓名 工资组成;部门分为:策划、美术、研发
●随机给10名员工分配部门和工资
●通过multimap进行信息的插入key(部门编号)value(员工)
●分部门显示员工信息

2.实现步骤

1.创建10名员工,放到vector中
2.遍历vector容器,取出每个员工,进行随机分组
3.分组后,将员工部门编号作为key,具体员工作为value,放入到multimap容器中
4.分部门显示员工信息

案例代码:

#include <iostream> using namespace std; #include <vector> #include <map> #include <ctime> /* 公司今天招聘了10个员工(ABCDEFGHIJ),10名员工进入公司之后,需要指派员工在那个部门工作 员工信息有:姓名 工资组成;部门分为:策划、美术、研发 随机给10名员工分配部门和工资 通过multimap进行信息的插入key(部门编号)value(员工) 分部门显示员工信息 */ #define CEHUA 0 #define MEISHU 1 #define YANFA 2 class Worker { public: Worker() { } string m_Name; int m_Salary; }; void createWorker(vector<Worker>&v) { string nameSeed = "ABCDEFGHIJ"; for (int i = 0; i < 10; i++) { Worker worker; worker.m_Name = "员工"; worker.m_Name += nameSeed[i]; worker.m_Salary = rand() % 10000 + 10000; //10000~19999 v.push_back(worker); } } //员工分组 void setGroup(vector<Worker>&v,multimap<int,Worker>&m) { for (vector<Worker>::iterator it = v.begin(); it != v.end(); it++) { //产生随机部门编号 int deptId = rand() % 3; //0,1,2 //插入数据 将员工插入分组中 //key部门编号 value具体员工 m.insert(make_pair(deptId,*it)); } } void showWorkerByGroup(multimap<int,Worker>&m) { cout << "策划部门:" << endl; multimap<int,Worker>::iterator pos = m.find(CEHUA); int count = m.count(CEHUA); //统计具体人数 int index = 0; for (; pos != m.end() && index < count; pos++, index++) { cout << "姓名:" << pos->second.m_Name << " 工资:" << pos->second.m_Salary << endl; } cout << "--------------------" << endl; cout << "美术部门:" << endl; pos = m.find(MEISHU); count = m.count(MEISHU); //统计具体人数 index = 0; for (; pos != m.end() && index < count; pos++, index++) { cout << "姓名:" << pos->second.m_Name << " 工资:" << pos->second.m_Salary << endl; } cout << "--------------------" << endl; cout << "研发部门:" << endl; pos = m.find(YANFA); count = m.count(YANFA); //统计具体人数 index = 0; for (; pos != m.end() && index < count; pos++, index++) { cout << "姓名:" << pos->second.m_Name << " 工资:" << pos->second.m_Salary << endl; } } int main() { srand((unsigned int)time(NULL)); //1.创建员工 vector<Worker>vWorker; createWorker(vWorker); // //测试 // for (vector<Worker>::iterator it = vWorker.begin(); it != vWorker.end(); it++) // { // cout << "姓名:" << it ->m_Name << " 工资:" << it ->m_Salary << endl; // } //2.分组 multimap<int,Worker>mWorker; setGroup(vWorker,mWorker); //3.分组显示员工 showWorkerByGroup(mWorker); return 0; }

写到后面:⭐如果本篇博文对你有帮助,那就 点赞 + 关注 + 收藏一下吧!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/19 1:41:33

读者写者问题与读写锁 [ 系统加餐 ]

读者写者问题读者写者问题它和生产者消费者模型一样&#xff0c;都是多线程同步与互斥的经典策略&#xff0c;从名称就能看出&#xff0c;该模型核心围绕读者与写者两种角色展开。生活中这类场景十分常见&#xff1a;比如我们发布博客&#xff0c;发布后很少修改&#xff0c;主…

作者头像 李华
网站建设 2026/4/19 1:40:30

从PID调参到根轨迹:一个电机控制工程师的实战避坑笔记

从PID调参到根轨迹&#xff1a;一个电机控制工程师的实战避坑笔记 作为一名在工业自动化领域摸爬滚打多年的电机控制工程师&#xff0c;我深知PID参数调试的痛点和挑战。每当面对一个全新的电机控制系统&#xff0c;传统的试凑法不仅耗时耗力&#xff0c;还常常陷入"调好一…

作者头像 李华
网站建设 2026/4/19 1:39:30

LeetCode 2958. 最多 K 个重复元素的最长子数组【不定长滑窗】1535

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…

作者头像 李华
网站建设 2026/4/19 1:37:18

告别HAL_Delay卡死:STM32中断服务函数里实现精准延时的3种替代方案

告别HAL_Delay卡死&#xff1a;STM32中断服务函数里实现精准延时的3种替代方案 在嵌入式开发中&#xff0c;中断服务函数(ISR)的设计直接影响系统的实时性和稳定性。许多开发者习惯性地在ISR中使用HAL_Delay这类阻塞式延时函数&#xff0c;结果发现系统莫名其妙地卡死。这背后隐…

作者头像 李华
网站建设 2026/4/19 1:37:17

洛阳静脉曲张自查:腿沉酸胀水肿,你需要注意的几大信号

大家好&#xff0c;今天咱们聊聊一个常见但又容易被忽视的问题——静脉曲张。特别是对于那些经常站立工作、久坐不动或者有家族史的朋友来说&#xff0c;了解静脉曲张的症状和预防措施尤为重要。下面&#xff0c;我们就一起来看看腿沉酸胀水肿等几个重要的信号&#xff0c;以及…

作者头像 李华