【面试总结-编程】多行两列数据,实现同key的value求和并输出

简介: 一个文件,两列,多行。第一列是字母,第二列是数字,同列数据之间通过空格分割。统计首列字母相同的第二列之和。样例输入:A 5B 6OO 7A 6A 2OO 2输出:A:13B:6OO:9面试官要求30分钟内实现,python,C++实现。

 

一个文件,两列,多行。

第一列是字母,第二列是数字,同列数据之间通过空格分割。

统计首列字母相同的第二列之和。

样例输入:

A 5

B 6

OO 7

A 6

A 2

OO 2

输出:

A:13

B:6

OO:9

面试官要求30分钟内实现,python,C++实现。

夸下5分钟写完一种语言海口的我花了18分钟睡觉……(晕)

然后开始整理思路,一开始写了很久vector+查找算法的(因为考虑map插入会导致覆盖),写了半天发现……太复杂了,而且查找算法确实应用的不熟练。后来转变一下思路map可以取出原来的值再加进去。。我去

捡起来半生不熟的map用法。。

思路就是:整个数据看作key-value结构,map的特性就是如果找一个不存在的,会自动插入并赋值默认值。value求和只需要找出对应key的map元素,取出当前的value(如果没有,int之类的默认是0),和新value相加后再塞回去。python直接利用字典这个结构即可。

 

 1 #include<map>
 2 #include<string>
 3 #include<iostream>
 4 #include<fstream>
 5 #include<sstream>
 6 
 7 using namespace std;
 8 
 9 typedef double datatype;
10 
11 template<typename T>
12 void Stringtoother(string str, T &result)//编写的模板函数供之后重用,实现字符串到任意类型(如果可以)的转换
13 {
14     istringstream is(str);
15     is >> result;
16 }
17 
18 int main(int argc, char** argv) {
19     map<string, datatype> mp;//声明最终存储的map
20 
21     ifstream in("D:\\test.txt");//测试样例,完全符合要求的情况下测试正常(未考虑文件出错的情况)
22 
23     //ifstream in(argv[1]);//实际的路径,可以通过cmd读取
24 
25     if (in.fail())
26     {
27         cout << "文件打开失败!" << endl;
28         system("pause");
29         return -1;
30     }
31 
32     string s;//文件读取每一行存储到的字符串
33     mp.clear();
34     while (getline(in, s))
35     {
36         int tag = s.find(" ");
37         string temp1, temp2;
38         temp1 = s.substr(0, tag - 1);
39         temp2 = s.substr(tag + 1, s.size());
40 
41         int value = 0;
42         Stringtoother(temp2, value);
43         mp[temp1] += value;//键值先读取原来的,然后再相加后覆盖
44 
45     }
46 
47     map<string, datatype>::iterator it;//最终结果输出
48     for (it = mp.begin(); it != mp.end(); it++) {
49         cout << it->first << ":" << it->second << endl;
50     }
51 
52     system("pause");
53     return 0;
54 }

python实现

 1 def readFile(path):
 2     dict_data={}
 3     with open(path,'r') as df:
 4         for kv in [d.strip().split(' ') for d in df]:
 5             temp=dict_data.get(kv[0],0)
 6             dict_data[kv[0]]=float(kv[1])+temp
 7     return dict_data;
 8 
 9 test_data={}
10 test_data=readFile("D:\\test.txt")
11 print(test_data)

 凉凉

目录
相关文章
|
22天前
|
SQL 缓存 easyexcel
面试官问10W 行级别数据的 Excel 导入如何10秒处理
面试官问10W 行级别数据的 Excel 导入如何10秒处理
50 0
|
2月前
|
NoSQL Java Redis
面试01-Redis 如何从海量数据中查询出某一个 Key
面试01-Redis 如何从海量数据中查询出某一个 Key
95 0
|
3月前
|
编解码 移动开发 前端开发
【面试题】 给你十万条数据,怎么样顺滑的渲染出来?
【面试题】 给你十万条数据,怎么样顺滑的渲染出来?
|
3月前
|
前端开发 JavaScript
【面试题】面试官:如果后端给你 1w 条数据,你如何做展示?
【面试题】面试官:如果后端给你 1w 条数据,你如何做展示?
|
6月前
|
Java
【面试题精讲】Java超过long类型的数据如何表示
【面试题精讲】Java超过long类型的数据如何表示
|
5月前
|
机器学习/深度学习 人工智能 算法
机器学习笔试面试之图像数据不足时的处理方法、检验方法、不均衡样本集的重采样
机器学习笔试面试之图像数据不足时的处理方法、检验方法、不均衡样本集的重采样
77 0
|
6天前
|
API Python
Python模块化编程:面试题深度解析
【4月更文挑战第14天】了解Python模块化编程对于构建大型项目至关重要,它涉及代码组织、复用和维护。本文深入探讨了模块、包、导入机制、命名空间和作用域等基础概念,并列举了面试中常见的模块导入混乱、不适当星号导入等问题,强调了避免循环依赖、合理使用`__init__.py`以及理解模块作用域的重要性。掌握这些知识将有助于在面试中自信应对模块化编程的相关挑战。
18 0
|
1月前
|
安全 算法 Java
Java 并发编程 面试题及答案整理,最新面试题
Java 并发编程 面试题及答案整理,最新面试题
92 0
|
2月前
|
存储 编译器 程序员
近4w字吐血整理!只要你认真看完【C++编程核心知识】分分钟吊打面试官(包含:内存、函数、引用、类与对象、文件操作)
近4w字吐血整理!只要你认真看完【C++编程核心知识】分分钟吊打面试官(包含:内存、函数、引用、类与对象、文件操作)
106 0
|
2月前
|
Java 关系型数据库 MySQL
面试官:如何实现10亿数据判重?
面试官:如何实现10亿数据判重?
50 0
面试官:如何实现10亿数据判重?