40 道高频 C++ 面试、笔试题及答案
1. 什么是多态?
答案: 多态允许对象在运行时表现出不同的行为,具体取决于其类型。
2. 虚函数和纯虚函数之间的区别是什么?
答案: 虚函数可以被派生类重写,而纯虚函数必须被派生类实现,否则派生类将成为抽象类。
3. 指针和引用的区别是什么?
答案: 指针存储变量的地址,而引用是变量的别名。引用必须初始化,而指针可以为 null。
4. 解释 C++ 中的内存管理。
答案: C++ 使用动态内存分配和释放,由 new 和 delete 运算符管理。
5. 什么是智能指针?
答案: 智能指针是自动管理内存的指针,例如 unique_ptr、shared_ptr 和 weak_ptr。
6. 解释 C++ 中的构造函数和析构函数。
答案: 构造函数在创建对象时被调用,析构函数在对象被销毁时被调用。
7. 什么是类的继承?
答案: 继承允许一个类(派生类)从另一个类(基类)继承数据成员和方法。
8. 解释 C++ 中的重载和重写。
答案: 重载允许具有相同名称但不同参数的多个函数,而重写允许派生类中的函数覆盖基类中的同名函数。
9. 什么是模板?
答案: 模板允许创建通用的代码,该代码可以在编译时根据不同类型进行实例化。
10. 解释 C++ 中的异常处理。
答案: 异常处理允许程序处理运行时错误,使用 try、catch 和 throw 关键字。
11. 什么是标准模板库 (STL)?
答案: STL 是一个提供容器、算法和迭代器的库。
12. 解释 C++ 中的流操作符。
答案: 流操作符(<< 和 >>)用于从流(例如文件或控制台)读取和写入数据。
13. 什么是 lambda 表达式?
答案: Lambda 表达式是匿名函数,可以捕获局部变量。
14. 解释 C++ 中的移动语义。
答案: 移动语义允许在不进行复制的情况下移动对象,从而提高效率。
15. 什么是 RTTI?
答案: RTTI(运行时类型信息)允许程序在运行时确定对象的类型。
16. 解释 C++ 中的友元。
答案: 友元是允许非成员函数访问私有或受保护成员的函数或类。
17. 什么是静态成员?
答案: 静态成员属于类而不是特定对象,并且在整个程序中共享。
18. 解释 C++ 中的析构函数顺序。
答案: 析构函数按相反的构造函数顺序调用。
19. 什么是虚继承?
答案: 虚继承允许派生类仅继承基类的指针,从而避免菱形继承问题。
20. 解释 C++ 中的内存对齐。
答案: 内存对齐确保对象在内存中存储在特定边界上,以提高性能。
21. 什么是位域?
答案: 位域允许将多个相关位打包到一个数据类型中。
22. 解释 C++ 中的枚举。
答案: 枚举是一种用户定义的数据类型,表示一组命名常量。
23. 什么是类型转换?
答案: 类型转换将一个数据类型转换为另一个数据类型。
24. 解释 C++ 中的预处理器宏。
答案: 预处理器宏允许在编译时执行文本替换。
25. 什么是编译期多态?
答案: 编译期多态允许在编译时确定函数或方法调用的行为。
26. 解释 C++ 中的虚基类。
答案: 虚基类允许派生类避免菱形继承问题,并确保只有一个基类的副本存储在派生类对象中。
27. 什么是多继承?
答案: 多继承允许一个类从多个基类继承。
28. 解释 C++ 中的异常规范。
答案: 异常规范允许函数指定它可能抛出的异常类型。
29. 什么是模板特化?
答案: 模板特化允许为特定类型提供模板的特定实现。
30. 解释 C++ 中的内存泄漏。
答案: 内存泄漏是指不再使用的内存未被释放,导致程序使用越来越多的内存。
31. 实现一个链表
struct Node {int data;Node* next;
};class LinkedList {
public:LinkedList();~LinkedList();void insert(int data);void delete(int data);bool search(int data);int size();
private:Node* head;Node* tail;
};
32. 实现一个栈
class Stack {
public:Stack();~Stack();void push(int data);int pop();bool empty();int size();
private:vector<int> elements;
};
33. 实现一个队列
class Queue {
public:Queue();~Queue();void enqueue(int data);int dequeue();bool empty();int size();
private:vector<int> elements;
};
34. 实现一个二叉树
struct Node {int data;Node* left;Node* right;
};class BinaryTree {
public:BinaryTree();~BinaryTree();void insert(int data);void delete(int data);bool search(int data);int size();
private:Node* root;
};
35. 实现一个哈希表
class HashTable {
public:HashTable(int size);~HashTable();void insert(int key, int value);int get(int key);bool contains(int key);
private:vector<pair<int, int>> elements;
};
36. 实现一个排序算法(如快速排序、归并排序)
void quickSort(int* arr, int low, int high) {if (low < high) {int pivot = partition(arr, low, high);quickSort(arr, low, pivot - 1);quickSort(arr, pivot + 1, high);}
}int partition(int* arr, int low, int high) {int pivot = arr[high];int i = low - 1;for (int j = low; j < high; j++) {if (arr[j] <= pivot) {i++;swap(arr[i], arr[j]);}}swap(arr[i + 1], arr[high]);return i + 1;
}
37. 实现一个字符串匹配算法(如 KMP 算法)
void kmp(string text, string pattern) {int n = text.length();int m = pattern.length();vector<int> lps(m);computeLPS(pattern, lps);int i = 0;int j = 0;while (i < n) {if (pattern[j] == text[i]) {i++;j++;}if (j == m) {cout << "Pattern found at index " << i - j << endl;j = lps[j - 1];} else if (i < n && pattern[j] != text[i]) {if (j != 0) {j = lps[j - 1];} else {i++;}}}
}void computeLPS(string pattern, vector<int>& lps) {int m = pattern.length();lps[0] = 0;int len = 0;int i = 1;while (i < m) {if (pattern[i] == pattern[len]) {len++;lps[i] = len;i++;} else {if (len != 0) {len = lps[len - 1];} else {lps[i] = 0;i++;}}}
}
38. 实现一个图的遍历算法(如 DFS、BFS)
void dfs(Graph& graph, int start) {stack<int> s;s.push(start);while (!s.empty()) {int v = s.top();s.pop();if (!graph.visited[v]) {graph.visited[v] = true;cout << v << " ";for (int u : graph.adj[v]) {if (!graph.visited[u]) {s.push(u);}}}}
}void bfs(Graph& graph, int start) {queue<int> q;q.push(start);while (!q.empty()) {int v = q.front();q.pop();if (!graph.visited[v]) {graph.visited[v] = true;cout << v << " ";for (int u : graph.adj[v]) {if (!graph.visited[u]) {q.push(u);}}}}
}
39. 实现一个动态规划算法(如背包问题)
int knapsack(int W, int wt[], int val[], int n) {int dp[n + 1][W + 1];for (int i = 0; i <= n; i++) {for (int j = 0; j <= W; j++) {if (i == 0 || j == 0) {dp[i][j] = 0;} else if (wt[i - 1] <= j) {dp[i][j] = max(val[i - 1] + dp[i - 1][j - wt[i - 1]], dp[i - 1][j]);} else {dp[i][j] = dp[i - 1][j];}}}return dp[n][W];
}
40. 实现一个贪心算法(如最小生成树)
class Edge {
public:int src;int dest;int weight;
};class Graph {
public:vector<Edge> edges;int V;int E;
};Graph* createGraph(int V, int E) {Graph* graph = new Graph();graph->V = V;graph->E = E;return graph;
}void addEdge(Graph* graph, int src, int dest, int weight) {Edge edge;edge.src = src;edge.dest = dest;edge.weight = weight;graph->edges.push_back(edge);
}int find(int parent[], int i) {if (parent[i] == -1) {return i;}return find(parent, parent[i]);
}void union(int parent[], int x, int y) {int xset = find(parent, x);int yset = find(parent, y);parent[xset] = yset;
}int kruskalMST(Graph* graph) {int V = graph->V;int E = graph->E;int parent[V];for (int i = 0; i < V; i++) {parent[i] = -1;}int mstWeight = 0;sort(graph->edges.begin(), graph->edges.end(), [](Edge a, Edge b) { return a.weight < b.weight; });for (int i = 0; i < E; i++) {Edge edge = graph->edges[i];int x = find(parent, edge.src);int y = find(parent, edge.dest);if (x != y) {mstWeight += edge.weight;union(parent, x, y);}}return mstWeight;
}
相关文章:
40 道高频 C++ 面试、笔试题及答案
1. 什么是多态? 答案: 多态允许对象在运行时表现出不同的行为,具体取决于其类型。 2. 虚函数和纯虚函数之间的区别是什么? 答案: 虚函数可以被派生类重写,而纯虚函数必须被派生类实现,否则派生…...
【07】进阶html5
HTML5 包含两个部分的更新,分别是文档和web api 文档 HTML5 元素表 元素语义化 元素语义化是指每个 HTML 元素都代表着某种含义,在开发中应该根据元素含义选择元素 元素语义化的好处: 利于 SEO(搜索引擎优化)利于无障碍访问利于浏览器的插件分析网页新增元素 多媒体…...
Linux|centos7|postgresql数据库|yum和编译方式安装总结(全系版本)
一、 yum方式安装postgresql 这个是官方的yum源,包括postgresql的开发包,lib库什么的,很齐全,关键是包括pgbackrest yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-la…...
C++提高笔记(五)---STL容器(set/multiset、map/multimap)
1、set / multiset容器 1.1set基本概念 简介:所有元素都会在插入时自动被排序 本质:set和multiset属于关联式容器,底层结构是用二叉树实现 set和multiset区别: set不允许容器中有重复的元素 multiset允许容器中有重复的元素 …...
详解main函数参数argc、argv及如何传参
目录 1、main()函数参数 2、main函数如何传参 2.1 环境准备 2.2 通过 Powershell 窗口传参 2.3 通过vs界面传参 3、int main() 和 int main(int argc, char *argv[]) 特点 1、main()函数参数 在C语言中,main函数可以带参数。main函数的原型通常为以下两种形式…...
解释什么是Web组件化开发及其优势
解释什么是Web组件化开发及其优势 Web组件化开发,是一种将Web应用的界面和功能拆分为独立、可复用的组件的开发方法。这种方法的核心思想是将大型、复杂的Web应用拆分为一系列小型、功能单一的组件,每个组件都负责处理特定的业务逻辑或界面表现。通过组…...
那些场景需要额外注意线程安全问题
主要学习那些场景需要额外注意线程安全问题,在这里总结了四中场景。 访问共享变量或资源 第一种场景是访问共享变量或共享资源的时候,典型的场景有访问共享对象的属性,访问static静态变量,访问共享的缓存,等等。因为…...
(C语言)球球大作战
前言: 这款简易版的球球大作战是一款单人游戏,玩家需要控制一个小球在地图上移动,吞噬其他小球来增大自己的体积。本游戏使用C语言和easyx图形库编写,旨在帮助初学者了解游戏开发的基本概念和技巧。 在开始编写代码之前…...
高级数据结构 <AVL树>
本文已收录至《数据结构(C/C语言)》专栏! 作者:ARMCSKGT 目录 前言正文AVL树的性质AVL树的定义AVL树的插入函数左单旋右单旋右左双旋左右双旋 检验AVL树的合法性关于AVL树 最后 前言 前面我们学习了二叉树,普通的二叉树没有任何特殊性质&…...
在springboot中利用Redis实现延迟队列
文章目录 前言一、基本思路二、springboot实现案例三、测试总结 前言 在开发过程中,有很多场景都需要用到延迟队列来解决。目前支持延迟队列的中间件也不少,特别是基于JMS模式下的消息中间件基本上都支持延迟队列。但是有时我们项目规模可能比较小&…...
UpGrow评论:AI能将我的Instagram粉丝数增加10倍吗?
UpGrow Review: Can AI Grow My Instagram Followers 10X? 概述 UpGrow是一款专注于Instagram增长的AI驱动型社交媒体工具。它通过其庞大的300多人的网络,先进的定位功能,实时分析以及卓越的客户服务,帮助用户有机地增长Instagram关注者。…...
申请软著提交的演示视频有什么要求
申请软件著作权时,演示视频是一个重要的材料,主要用于展示软件的功能和操作流程。演示视频的要求可能会根据不同的申请机构和项目有所不同,但一般来说,以下是几个常见的要求: 内容完整性:演示视频需要展示…...
mac【启动elasticsearch报错:can not run elasticsearch as root
mac【启动elasticsearch报错:can not run elasticsearch as root 问题原因 es默认不能用root用户启动,生产环境建议为elasticsearch创建用户。 解决方案 为elaticsearch创建用户并赋予相应权限。 尝试了以下命令创建用户,adduser esh 和u…...
面试算法-65-二叉树的层平均值
题目 给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10-5 以内的答案可以被接受。 示例 1: 输入:root [3,9,20,null,null,15,7] 输出:[3.00000,14.50000,11.00000] 解释:第 0 层的…...
Linux: boot: latency启动延迟分析
https://elinux.org/images/6/64/Chris-simmonds-boot-time-elce-2017_0.pdf https://www.hcltech.com/sites/default/files/documents/resources/whitepaper/files/an_insight_to_optimize_embedded_linux_boot_time_performance.pdf 无意看到这个启动延迟分析,虽…...
QT界面制作
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);this->setWindowFlag(Qt::FramelessWindowHint);//接收动图QMovie *mv new QMovie(":/pictrue/th.gif…...
进阶二叉树
目录 二叉树 二叉搜索树 二叉搜索树的定义 二叉搜索树的操作 哈夫曼树 哈夫曼树的定义 哈夫曼树的构造 哈夫曼树的性质 平衡二叉树 平衡二叉树的定义: 平衡二叉树的插入调整 1.LL插入/LL旋转 2.RR插入/RR旋转 3.LR插入/LR旋转 4.RL插入/RL旋转 二叉树…...
无人机拦截
配置yolo CUDA报错 nvcc fatal : Unsupported gpu architecture compute_30.(1)查看显卡匹配型号:https://blog.csdn.net/u013308762/article/details/121658823 (2)查看显卡:nvidia-smi -a 》NVIDIA GeF…...
CSDN 编辑器设置图片缩放和居中
CSDN 编辑器设置图片缩放和居中 文章目录 CSDN 编辑器设置图片缩放和居中对齐方式比例缩放 对齐方式 Markdown 编辑器插入图片的代码格式为 CSDN 的 Markdown 编辑器中插入图片,默认都是左对齐,需要设置居中对齐的话,…...
有哪些工具可以替代Gitbook?这篇文章告诉你
你是否曾经在搜索在线文档创建和共享工具时,遇到了Gitbook? Gitbook 是一个相当出色的工具,具有强大的编辑和发布功能,但也有其不足之处,如使用起来有一定的技术要求,入门门槛较高等。如果你正在寻找Gitbook的替代品&…...
相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了: 这一篇我们开始讲: 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下: 一、场景操作步骤 操作步…...
1688商品列表API与其他数据源的对接思路
将1688商品列表API与其他数据源对接时,需结合业务场景设计数据流转链路,重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点: 一、核心对接场景与目标 商品数据同步 场景:将1688商品信息…...
Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级
在互联网的快速发展中,高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司,近期做出了一个重大技术决策:弃用长期使用的 Nginx,转而采用其内部开发…...
论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(一)
宇树机器人多姿态起立控制强化学习框架论文解析 论文解读:交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(一) 论文解读:交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化…...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...
智能AI电话机器人系统的识别能力现状与发展水平
一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...
安宝特案例丨Vuzix AR智能眼镜集成专业软件,助力卢森堡医院药房转型,赢得辉瑞创新奖
在Vuzix M400 AR智能眼镜的助力下,卢森堡罗伯特舒曼医院(the Robert Schuman Hospitals, HRS)凭借在无菌制剂生产流程中引入增强现实技术(AR)创新项目,荣获了2024年6月7日由卢森堡医院药剂师协会࿰…...
scikit-learn机器学习
# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...
Vue3中的computer和watch
computed的写法 在页面中 <div>{{ calcNumber }}</div>script中 写法1 常用 import { computed, ref } from vue; let price ref(100);const priceAdd () > { //函数方法 price 1price.value ; }//计算属性 let calcNumber computed(() > {return ${p…...
java高级——高阶函数、如何定义一个函数式接口类似stream流的filter
java高级——高阶函数、stream流 前情提要文章介绍一、函数伊始1.1 合格的函数1.2 有形的函数2. 函数对象2.1 函数对象——行为参数化2.2 函数对象——延迟执行 二、 函数编程语法1. 函数对象表现形式1.1 Lambda表达式1.2 方法引用(Math::max) 2 函数接口…...
