2019-09-29商泰汽车面试手撕STL代码之后知后觉的凉凉夜色

2023-10-11 07:50

本文主要是介绍2019-09-29商泰汽车面试手撕STL代码之后知后觉的凉凉夜色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、问题:使用list或者vector容器,对其中的数据(包括重复数据)进行筛查,找出该容器中第三大的数据并输出。

 

二、我的思路

1. 由于有很多不确定的重复数据,于是想到要使用两个容器A、B;

2. 容器A中包含源数据,容器B中存放降序且不重复的数据;再利用at()直接输出第三大的数据即可。

3. 对A进行降序排序,容器怎么排?(冒泡、迭代器)

4. 对容器A进行去重并插入至容器B(如何去重?)

 

三、 实现

#include <iostream>
#include <iterator>
#include <vector>
using namespace std;void swap(int &a, int &b);
void sort(vector<int> &obj);int main()
{vector<int> *src = new vector<int>;//排序容器srcvector<int> *fin = new vector<int>;//去重,并输出第三大的数字容器finfor(int i = 0; i < 10; i++)src->push_back(rand()%20+1);//插入一个1-20的随机数if(src->empty()){cout << "插入数据失败" << endl;exit(-1);}cout << "原容器中的数据为:" << endl;for(vector<int>::iterator it = src->begin(); it != src->end(); it++)cout << *it << " ";cout << endl;//先对原来的数据执行排序(包括重复的数据)sort(*src);cout << "原容器排序后的数据为:" << endl;for(int i = 0; i < src->size(); i++)cout << src->at(i) << " ";cout << endl;for(int i = 0; i < src->size(); i++)//去重{//判断最后一个是不是和排好序中的容器遍历值相等,若相等则跳过if((fin->empty()) || (fin->back() != src->at(i))){fin->push_back(src->at(i));}else {continue;}}cout << "去重后的数据为:" << endl;for(int i = 0; i < fin->size(); i++)cout << fin->at(i) << " ";cout << endl;cout << "第三大的数字是:" << fin->at(2) << endl;;delete src;delete fin;return 0;
}void swap(int & a, int & b)
{a ^= b;b ^= a;a ^= b;
}void sort(vector<int> &obj)
{vector<int>::iterator it = obj.begin();int len = obj.size();for(int i = 0; i < len - 1; i++)for(int j = 0; j < len - i - 1; j++)if((obj[j]) < (obj[j+1]))swap(obj[j], obj[j+1]);
}

 

四、编译运行


我当时就想,怎么这么简单的问题?

诶,可结果就是:没把它写得完整,可能面试官跟你面对面交谈想问题真的是太不冷静了。

在此写下人生中的错过和锻炼,真的很值得反思。

 

这篇关于2019-09-29商泰汽车面试手撕STL代码之后知后觉的凉凉夜色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/186627

相关文章

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1