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

相关文章

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据