排列员工工资顺序(C++map解法)

题目描述:
某公司中有N名员工给定所有员工工资的清单,财务人员要按照特定的顺序排列员工的工资。他按照工资的频次降序排列。即给定清单中所有频次较高的工资将在频次较低的工资之前出现。如果相同数量的员工都有相同的工资,则将按照给定清单中该工资第一次出现的顺序排列。
写一个算法来帮助财务人员排列员工工资的顺序。

输入:
该函数/方法的输入包括两个参数------
num,一个整数,表示员工的人数
salaries,一个正整数列表,表示N名员工的工资

输出:
返回一个正整数列表,该列表按照员工工资的频次排序。

约束条件:
1<num<100000
1<salaries<1000000000
0<i<num

示例:
输入:num=19
salaries=[10000,20000,40000,30000,30000,30000,40000,20000,50000,50000,50000,50000,60000,60000,60000,70000,80000,90000,100000]

输出:
[50000,50000,50000,50000,30000,30000,30000,60000,60000,60000,20000,20000,40000,40000,10000,70000,80000,90000,100000]

解题思路:使用map保存工资出现的频次,若没有该条工资,加入;若有该条工资,频次+1。然后遍历map找频次的最大值,根据频次吧key值加入vector中,然后删除该条记录,直到map为空。返回vector即可。

#include <map>
#include <vector> using namespace std; int main()
{
int num = ;
int *salaries = new int[]{ ,,,,,,,,,,,,,,,,,, };
vector<int> result = salaryFrequeny(, salaries);
system("pause");
return ;
} vector<int> salaryFrequeny(int num, int *salaries)
{
map<int, int> safMap;
map<int, int>::iterator iter;
for (int i = ; i < num; i++)
{
iter = safMap.find(salaries[i]);
if (iter == safMap.end())
{
safMap.insert(pair<int, int>(salaries[i], ));//没找到key值,向map加入。
}
else
{
iter->second += ;//找到key值,对应的value+1
}
}
vector<int> result;
int max = ;
int index = ;
while (safMap.size())
{
for (iter = safMap.begin(); iter != safMap.end(); iter++)//找当前频次最高的记录
{
if (iter->second > max)
{
max = iter->second;
index = iter->first;
}
}
while (max--)
{
result.push_back(index);//将频次最高的key值按频次压入vector
}
safMap.erase(index);//擦除当前频次最高的记录
}
return result;
}

【转载自】

627在线笔试题:排列员工工资顺序(C++map解法) - 懂代码的暖男 - CSDN博客

题目:排列员工工资顺序(Java和C++)(中兴在线笔试题) - 会笑的小猪的博客 - CSDN博客

题目描述:
某公司中有N名员工。给定所有员工工资的清单,财务人员要按照特定的顺序排列员工的工资。他按照工资的频次降序排列。即给定清单中所有频次较高的工资将在频次较低的工资之前出现。如果相同数量的员工都有相同的工资,则将按照给定清单中该工资第一次出现的顺序排列。
写一个算法来帮助财务人员排列员工工资的顺序。
��
输入:
该函数/方法的输入包括两个参数------
num,一个整数,表示员工的人数
salaries,一个正整数列表,表示N名员工的工资
输出:
返回一个正整数列表,该列表按照员工工资的频次排序。
约束条件:
<num<
<salaries<
<i<num
��
示例:
输入:
num=
salaries=[,,,,,,,,,
,,,,,,,,,]
输出:
[,,,,,,,,,
,,,,,,,,,]
��
��
分析:本题要求把根据数据出现的频数从高到低排序,所以基本的思路是算出每个数的频次,然后直接从高到低排序。
�� �� �� �� �� ��2可是这样会出现一个问题,频次相同的数据没法排序。比如 ���� 这组数据分别得到频次 ,本身就是一个降序排序,所以最后结果还是20
�� �� �� �� �� ��2那怎么办呢?我们可以上面那种数据中间那个20为例,即20 。首先我们来判断20的前半部分是否存在20,如果存在20的话则插入到该20的后面即可,即变为20 。
�� �� �� �� �� ��2所有排序过程均使用插入排序。插入排序的详细原理读者可以自行百度,插入排序从后往前移动,移动过程中不会改变原有已经排列好的数字的顺序。
��
思路:.计算每个数的频数。
�� �� �� �� �� ��.根据频数的大小,对数据从高到低排序。排序的方法使用插入排序。
�� �� �� �� �� . 对第2部排好序的结果再排序。这次从前向后遍历,判断该数的前半部分是否存在该数,存在的话就插入到最近和它相同数的后面。 Java实现:
在线运行代码
public class salaryArrangement { public static void main(String[] args) {
int num = ;
int slalay[] = { , , , , , , , , , , , , ,
, , , , , };// 测试数据
slalay = b(num, slalay); // 保存结果
int i;
System.out.println("输出结果为:");
for (i = ; i < num; i++)// 输出结果
{
System.out.print(" ");
System.out.print(slalay[i]);
}
} public static int[] b(int num, int slalay[]) {
int i, j, k;
int temp_frequency;
int temp_slalay;
int frequency[] = new int[num]; // 频次
for (i = ; i < num; i++) // 给频次赋初值
{
frequency[i] = ;
} for (i = ; i < num; i++) // 对已排序的数据统计频次
{
for (j = ; j < num; j++) {
if (slalay[i] == slalay[j])
{
frequency[i]++;
}
}
} for (i = ; i < num; i++) // 对频次进行插入排序,同时根据频数交换的顺序排列原数据
{
temp_frequency = frequency[i];
temp_slalay = slalay[i];
j = i - ;
while (j >= && temp_frequency > frequency[j]) //频次递减排序
{
frequency[j + ] = frequency[j];
slalay[j + ] = slalay[j]; // 变换原数据
j--;
}
frequency[j + ] = temp_frequency;
slalay[j + ] = temp_slalay;
} for (i = ; i < num; i++) // 再进行一次插入排序
{
temp_slalay = slalay[i];
j = i - ;
k = i - ;
while (k >= )
{
if (temp_slalay == slalay[k]) // 判断前半部分子序列是否存在当前当前数据
{
while (j >= && temp_slalay != slalay[j]) // 插入到相同的数的后面
{
slalay[j + ] = slalay[j];
j--;
}
slalay[j + ] = temp_slalay;
break; // 退出循环判断下个数
}
k--;
} } return slalay;
}
} C++实现:
在线运行代码
#include <stdio.h> int* b(int num, int* slalay) {
int i, j, k;
int temp_frequency;
int temp_slalay;
int frequency[num]; // 频次
for (i = ; i < num; i++) // 给频次赋初值
{
frequency[i] = ;
} for (i = ; i < num; i++) // 对已排序的数据统计频次
{
for (j = ; j < num; j++) {
if (slalay[i] == slalay[j])
{
frequency[i]++;
}
}
} for (i = ; i < num; i++) // 对频次进行插入排序,同时根据频数交换的顺序排列原数据
{
temp_frequency = frequency[i];
temp_slalay = slalay[i];
j = i - ;
while (j >= && temp_frequency > frequency[j]) //频次递减排序
{
frequency[j + ] = frequency[j];
slalay[j + ] = slalay[j]; // 变换原数据
j--;
}
frequency[j + ] = temp_frequency;
slalay[j + ] = temp_slalay;
} for (i = ; i < num; i++) // 再进行一次插入排序
{
temp_slalay = slalay[i];
j = i - ;
k = i - ;
while (k >= )
{
if (temp_slalay == slalay[k]) // 判断前半部分子序列是否存在当前当前数据
{
while (j >= && temp_slalay != slalay[j]) // 插入到相同的数的后面
{
slalay[j + ] = slalay[j];
j--;
}
slalay[j + ] = temp_slalay;
break; // 退出循环判断下个数
}
k--;
} } return slalay;
} int main()
{
int num = ;
int slalay[] = { , , , , , , , , ,
, , , ,, , , , , };// 测试数据
int *slalayResult;
slalayResult = b(num, slalay); // 保存结果
int i;
printf("输出结果为:");
for (i = ; i < num; i++)// 输出结果
{
printf("%d ",slalayResult[i]);
}
}

【笔试题】某公司中有N名员工。给定所有员工工资的清单的更多相关文章

  1. 关于完整解答Leo C.W博客中名为“我们公司的ASP.NET 笔试题,你觉得难度如何”的所有题目

    关于完整解答Leo C.W博客中名为“我们公司的ASP.NET 笔试题,你觉得难度如何”的所有题目,请大家鉴定,不足之处,敬请指教! 第1到3题解答如下: public enum QuestionTy ...

  2. java各公司笔试题集1

    IBM笔试题 注:IBM笔试题一小时之内完成,题目全部用英文描述,这里用中文表述 一.名词解释 1.Eclipse 2.J2EE 3.EJB 4.Ajax 5.Web service 二.找出以下代码 ...

  3. 某公司的U3D笔试题

    某公司的U3D笔试题   今天这套笔试题感觉做得一般. 随后是二对一的技术面试,但涉及的技术细节相对较少,更多的是对以前工作.项目经历的询问. 然后说今天先到这里,让我等通知. 我还特意问了一下,通知 ...

  4. 所在实习公司的JS笔试题

    在班上无聊的时候看到了一份JS笔试题(我是电面进去的,没做过这份题~~),开始还觉得蛮简单......后来觉得还是很有意思的,贴出来一起看看. 题目一: if(!("a" in w ...

  5. 收藏所用C#技术类面试、笔试题汇总

    技术类面试.笔试题汇总 注:标明*的问题属于选择性掌握的内容,能掌握更好,没掌握也没关系. 下面的参考解答只是帮助大家理解,不用背,面试题.笔试题千变万化,不要梦想着把题覆盖了,下面的题是供大家查漏补 ...

  6. 一道简单的 Java 笔试题,但值得很多人反思!

    前言 面试别人,对我来说是一件新奇事,以前都是别人面试我.我清楚地知道,我在的地域与公司,难以吸引到中国的一流软件人才.所以,我特地调低了期望,很少问什么深入的技术问题,只问一些广泛的.基础的.我只要 ...

  7. C/C++ 笔试题

    /////转自http://blog.csdn.net/suxinpingtao51/article/details/8015147#userconsent# 微软亚洲技术中心的面试题!!! 1.进程 ...

  8. 嵌入式Linux C笔试题积累(转)

    http://blog.csdn.net/h_armony/article/details/6764811 1.   嵌入式系统中断服务子程序(ISR) 中断是嵌入式系统中重要的组成部分,这导致了很 ...

  9. C/C++笔试题(很多)

    微软亚洲技术中心的面试题!!! .进程和线程的差别. 线程是指进程内的一个执行单元,也是进程内的可调度实体. 与进程的区别: (1)调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位 (2 ...

随机推荐

  1. Keras实现Self-Attention

    本文转载自:https://blog.csdn.net/xiaosongshine/article/details/90600028 一.Self-Attention概念详解 对于self-atten ...

  2. C++(三十五) — 运算符重载

    运算符重载的实质:函数重载.除了增加一个关键字 operator 外,与函数重载没有区别,都是通过该类的某个对象来访问重载运算符. (1)重载运算符时,运算符运算顺序和优先级不变,操作数个数不变: ( ...

  3. python网络-静态Web服务器案例(29)

    一.静态Web服务器案例代码static_web_server.py # coding:utf-8 # 导入socket模块 import socket # 导入正则表达式模块 import re # ...

  4. MQ的常见应用场景

    MQ的常见的应用场景为:解耦,异步,流量削峰 在解耦场景中: 不使用MQ的耦合场景: 使用解耦的场景为: 异步的方式: 不使用MQ的同步高延时请求场景: 使用异步化之后的接口性能优化: 没有使用mq的 ...

  5. 《CoderXiaoban》第八次团队作业:Alpha冲刺1

    项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 实验十二 团队作业8:软件测试与ALPHA冲刺 团队名称 Coderxiaoban团队 作业学习目标 (1)掌握软件测试基 ...

  6. mysql-proxy读写分离笔记

    1.MySQL的安装与配置 --省略 版本:Server version: 5.6.35 1.1 系统版本: [root@centos7-67 package]# lsb_release -a LSB ...

  7. PHP——获取当前时间精确到毫秒(yyyyMMddHHmmssSSS)

    前言 emmmmmm,别说话,我们偷偷偷狗子 格式 | yyyyMMddHHmmssSSS 代码 获取毫秒 //获取当前时间毫秒 function msectime() { list($msec, $ ...

  8. 2019-2020-1 20199312《Linux内核原理与分析》第十一周作业

    实验简介 缓冲区溢出是指程序试图向缓冲区写入超出预分配固定长度数据的情况.这一漏洞可以被恶意用户利用来改变程序的流控制,甚至执行代码的任意片段.这一漏洞的出现是由于数据缓冲器和返回地址的暂时关闭,溢出 ...

  9. django项目部署服务器后无法发送邮箱 错误信息:Connection unexpectedly closed

    使用配置: python 3.7 + django 2.2.1    发送邮件模块 :  from django.core.mail import send_mail 服务器:Centos7 阿里云轻 ...

  10. SpringBoot测试Controller层

    一.准备工作 1.导入测试依赖 <dependency> <groupId>org.springframework.boot</groupId> <artif ...