【C++ STL小案例】--员工分组

本文主要以员工分组为例介绍STL综合性的案例。目录如下,建议收藏阅读

文章目录

一、案例描述

公司今天招募了10个员工(ABCDEFGHIJ),10名员工进入公司之后,需要指派员工在那个部门工作。

员工信息由:姓名 工资。部门为:策划、美术、研发。

随机给10名员工分配部门和工资。

通过multimap进行信息的插入。key(部门编号)value(员工)

分部门显示员工信息。

二、实现思路分析

1、案例框架搭建

创建10名员工,放到vector中

遍历vector容器,取出每个员工,进行随机分组。

分组后,将员工部门编号为key,具体员工作为value,放入到multimao容器中。

分部门显示员工信息。

cpp 复制代码
    //1、创建员工
    CreatWorker(vWorker);

    //2、分组
    setGroup(vWorker,mWorker);

    //3、分组显示员工
    ShowWorkerByGroup(mWorker);

2、业务函数实现

cpp 复制代码
void CreatWorker(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 depID = rand() % 3;

        //将员工插入到分组中
        m.insert(pair<int, Worker>(depID, *it));
    }

}
void ShowWorkerByGroup(multimap<int, Worker> &m)
{
    cout << "========策划部门=========" << endl;
    multimap<int,Worker>::iterator pos = m.find(CEHUA);
    int count = (int)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;
    count = (int)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;
    count = (int)m.count(YANFA);
    index = 0;
    for (; pos != m.end() && index < count; pos++, index++)
    {
        cout << "姓名: " << pos->second.m_Name << " 工资: " << pos->second.m_Salary << endl;
    }
}

三、运行结果

相关推荐
闻缺陷则喜何志丹几秒前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径
charlie11451419112 分钟前
C++ STL CookBook
开发语言·c++·stl·c++20
袁袁袁袁满12 分钟前
100天精通Python(爬虫篇)——第113天:‌爬虫基础模块之urllib详细教程大全
开发语言·爬虫·python·网络爬虫·爬虫实战·urllib·urllib模块教程
ELI_He99918 分钟前
PHP中替换某个包或某个类
开发语言·php
小林熬夜学编程23 分钟前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
m0_7482361126 分钟前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust
倔强的石头10634 分钟前
【C++指南】类和对象(九):内部类
开发语言·c++
Watermelo61738 分钟前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
A懿轩A2 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
机器视觉知识推荐、就业指导2 小时前
C++设计模式:享元模式 (附文字处理系统中的字符对象案例)
c++