【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;
    }
}

三、运行结果

相关推荐
南方的狮子先生2 分钟前
【数据结构】(C++数据结构)查找算法与排序算法详解
数据结构·c++·学习·算法·排序算法·1024程序员节
紫荆鱼14 分钟前
设计模式-适配器模式(Adapter)
c++·设计模式·适配器模式
一只小透明啊啊啊啊20 分钟前
Java的中间件
java·开发语言·中间件
学编程就要猛35 分钟前
数据结构初阶:Java中的ArrayList
java·开发语言·数据结构
JH307337 分钟前
10分钟理解泛型的通配符(extends, super, ?)
java·开发语言·windows
Tony Bai1 小时前
【Go模块构建与依赖管理】01 前世今生:从 GOPATH 的“混乱”到 Go Modules 的“秩序”
开发语言·后端·golang
缺点内向1 小时前
Java 使用 Spire.XLS 库合并 Excel 文件实践
java·开发语言·excel
.NET修仙日记2 小时前
Visual Studio 演进之路:从集成套件到AI驱动的开发平台
ide·编辑器·ai编程·visual studio·1024程序员节
獨枭2 小时前
Visual Studio 编译带显卡加速的 OpenCV
ide·opencv·visual studio