当前位置: 首页 > news >正文

CCF编程能力等级认证GESP—C++6级—20250927

CCF编程能力等级认证GESP—C++6级—20250927

  • 单选题(每题 2 分,共 30 分)
  • 判断题(每题 2 分,共 20 分)
  • 编程题 (每题 25 分,共 50 分)
    • 划分字符串
    • 货物运输

单选题(每题 2 分,共 30 分)

1、下列关于类的说法,错误的是( )。

A. 构造函数不能声明为虚函数,但析构函数可以。
B. 函数参数如声明为类的引用类型,调用时不会调用该类的复制构造函数。
C. 静态方法属于类而不是某个具体对象,因此推荐用 类名::方法(...) 调用。
D. 不管基类的析构函数是否是虚函数,都可以通过基类指针/引用正确删除派生类对象。

正确答案:D

2、假设变量 veh 是类 Car 的一个实例,我们可以调用 veh.move() ,是因为面向对象编程有( )性质。

class Vehicle {
private:string brand;
public:Vehicle(string b) : brand(b) {}void setBrand(const string& b) { brand = b; }string getBrand() const { return brand; }void move() const {cout << brand << " is moving...	" << endl;}
};
class Car : public Vehicle {
private:int seatCount;
public:Car(string b, int seats) : Vehicle(b), seatCount(seats) {}void showInfo() const {cout << "This car is a " << getBrand()<< " with " << seatCount << " seats." << endl;}
};
A. 继承 (Inheritance)
B. 封装 (Encapsulation)
C. 多态 (Polymorphism)
D. 链接 (Linking)

正确答案:A

3、下面代码中 v1 和 v2 调用了相同接口 move() ,但输出结果不同,这体现了面向对象编程的( )特性。

class Vehicle {
private:string brand;
public:Vehicle(string b) : brand(b) {}void setBrand(const string& b) { brand = b; }string getBrand() const { return brand; }virtual void move() const {cout << brand << " is moving...	" << endl;}
};
class Car : public Vehicle {
private:int seatCount;
public:Car(string b, int seats) : Vehicle(b), seatCount(seats) {}void showInfo() const {cout << "This car is a " << getBrand()<< " with " << seatCount << " seats." << endl;}void move() const override {cout << getBrand() << " car is driving on the road!" << endl;}
};
class Bike : public Vehicle {
public:Bike(string b) : Vehicle(b) {}void move() const override {cout << getBrand() << " bike is cycling on the path!" << endl;}
};
int main() {Vehicle* v1 = new Car("Toyota", 5);Vehicle* v2 = new Bike("Giant");v1->move();v2->move();delete v1;delete v2;return 0;
}
A. 继承 (Inheritance)
B. 封装 (Encapsulation)
C. 多态 (Polymorphism)
D. 链接 (Linking)

正确答案:C

4、栈的操作特点是( )。

A. 先进先出
B. 先进后出
C. 随机访问
D. 双端进出

正确答案:B

5、循环队列常用于实现数据缓冲。假设一个循环队列容量为 5 (即最多存放 4 个元素,留一个位置区分空与满),依次进行操作:入队数据1,2,3,出队1个数据,再入队数据4和5,此时队首到队尾的元素顺序是( )。

A. [2, 3, 4, 5]
B. [1, 2, 3, 4]
C. [3, 4, 5, 2]
D. [2, 3, 5, 4]

正确答案:A

6、以下函数 createTree() 构造的树是什么类型?

struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
TreeNode* createTree() {TreeNode* root = new TreeNode(1);root->left = new TreeNode(2);root->right = new TreeNode(3);root->left->left = new TreeNode(4);root->left->right = new TreeNode(5);return root;
}
A. 满二叉树
B. 完全二叉树
C. 二叉排序树
D. 其他都不对

正确答案:B

7、已知二叉树的 中序遍历 是 [D, B, E, A, F, C],先序遍历 是 [A, B, D, E, C, F]。请问该二叉树的后序遍历结果是( )。

A. [D, E, B, F, C, A]
B. [D, B, E, F, C, A]
C. [D, E, B, C, F, A]
D. [B, D, E, F, C, A]

正确答案:A

8、完全二叉树可以用数组连续高效存储,如果节点从 1 开始编号,则对有两个孩子节点的节点 i ,( )。

A. 左孩子位于 2i ,右孩子位于 2i+1
B. 完全二叉树的叶子节点可以出现在最后一层的任意位置
C. 所有节点都有两个孩子
D. 左孩子位于 2i+1 ,右孩子位于 2i+2

正确答案:A

9、设有字符集 {a, b, c, d, e, f} ,其出现频率分别为 {5, 9, 12, 13, 16, 45}。哈夫曼算法构造最优前缀编码,以下哪一组可能是对应的哈夫曼编码?(非叶子节点左边分支记作 0,右边分支记作 1,左右互换不影响正确性)。

A. a: 00;b: 01;c: 10;d: 110;e: 111;f: 0
B. a: 1100;b: 1101;c: 100;d: 101;e: 111;f: 0
C. a: 000;b: 001;c: 01;d: 10;e: 110;f: 111
D. a: 10;b: 01;c: 100;d: 101;e: 111;f: 0

正确答案:B

10、下面代码生成格雷编码,则横线上应填写( )。

vector<string> grayCode(int n) {if (n == 0) return {"0"};if (n == 1) return {"0","1"};vector<string> prev = grayCode(n-1);vector<string> result;for (string s : prev) {result.push_back("0" + s);}for (_______________) { // 在此处填写代码result.push_back("1" + prev[i]);}return result;
}
A. int i = 0; i < prev.size(); i++
B. int i = prev.size()-1; i >= 0; i--
C. auto s : prev
D. int i = prev.size()/2; i < prev.size(); i++

正确答案:B

11、请将下列树的深度优先遍历代码补充完整,横线处应填入( )。

struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x): val(x), left(nullptr), right(nullptr) {}
};
void dfs(TreeNode* root) {if (!root) return;______<TreeNode*> temp; // 在此处填写代码temp.push(root);while (!temp.empty()) {TreeNode* node = temp.top();temp.pop();cout << node->val << " ";if (node->right) temp.push(node->right);if (node->left) temp.push(node->left);}
}
A. vector
B. list
C. queue
D. stack

正确答案:D

12、令n是树的节点数目,下列代码实现了树的广度优先遍历,其时间复杂度是( )。

void bfs(TreeNode* root) {if (!root) return;queue<TreeNode*> q;q.push(root);while (!q.empty()) {TreeNode* node = q.front();q.pop();cout << node->val << " ";if (node->left) q.push(node->left);if (node->right) q.push(node->right);}
}

A. O(n)O(n)O(n)
B. O(logn)O(logn)O(logn)
C. O(n2)O(n^2)O(n2)
D. O(2n)O(2^n)O(2n)

正确答案:A

13、在二叉排序树(Binary Search Tree, BST)中查找元素 50 ,从根节点开始:若根值为 60 ,则下一步应去搜索:

A. 左子树
B. 右子树
C. 随机
D. 根节点

正确答案:A

14、删除二叉排序树中的节点时,如果节点有两个孩子,则横线处应填入( ),其中 findMax 和 findMin 分别为寻找树的最大值和最小值的函数。

struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x): val(x), left(nullptr), right(nullptr) {}
};
TreeNode* deleteNode(TreeNode* root, int key) {if (!root) return nullptr;if (key < root->val) {root->left = deleteNode(root->left, key);}else if (key > root->val) {root->right = deleteNode(root->right, key);}else {if (!root->left) return root->right;if (!root->right) return root->left;TreeNode* temp = ____________; // 在此处填写代码root->val = temp->val;root->right = deleteNode(root->right, temp->val);}return root;
}
A. root->left
B. root->right
C. findMin(root->right)
D. findMax(root->left)

正确答案:C

15、给定n个物品和一个最大承重为w的背包,每个物品有一个重量wt[i]和val[i]价值 ,每个物品只能选择放或不放。目标是选择若干个物品放入背包,使得总价值最大,且总重量不超过W,则横线上应填写( )。

int knapsack(int W, vector<int>& wt, vector<int>& val, int n) {vector<int> dp(W+1, 0);for (int i = 0; i < n; ++i) {for (int w = W; w >= wt[i]; --w) {________________________ // 在此处填写代码}}return dp[W];
}
A. dp[w] = max(dp[w], dp[w] + val[i]);
B. dp[w] = dp[w - wt[i]] + val[i];
C. dp[w] = max(dp[w - 1], dp[w - wt[i]] + val[i]);
D. dp[w] = max(dp[w], dp[w - wt[i]] + val[i]);

正确答案:D

判断题(每题 2 分,共 20 分)

1、当基类可能被多态使用,其析构函数应该声明为虚函数。

正确答案:正确

2、哈夫曼编码是最优前缀码,且编码结果唯一。

正确答案:错误

3、一个含有100个节点的完全二叉树,高度为8。

正确答案:错误

4、在 C++ STL 中,栈( std::stack )的 pop 操作返回栈顶元素并移除它。

正确答案:错误

5、循环队列通过模运算循环使用空间。

正确答案:正确

6、一棵有n个节点的二叉树一定有n-1条边。

正确答案:正确

7、以下代码实现了二叉树的中序遍历。输入以下二叉树,中序遍历结果是 4 2 5 1 3 6 。

// 1
// / \
// 2 3
// / \ \
// 4 5 6
struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
void inorderIterative(TreeNode* root) {stack<TreeNode*> st;TreeNode* curr = root;while (curr || !st.empty()) {while (curr) {st.push(curr);curr = curr->left;}curr = st.top(); st.pop();cout << curr->val << " ";curr = curr->right;}
}

正确答案:正确

8、下面代码实现的二叉排序树的查找操作时间复杂度是O(h),其中h为树高。

TreeNode* searchBST(TreeNode* root, int val) {while (root && root->val != val) {root = (val < root->val) ? root->left : root->right;}return root;
}

正确答案:正确

9、下面代码实现了动态规划版本的斐波那契数列计算,其时间复杂度是O(2n)O(2^n)O(2n)

int fib_dp(int n) {if (n <= 1) return n;vector<int> dp(n+1);dp[0] = 0;dp[1] = 1;for (int i = 2; i <= n; i++) {dp[i] = dp[i-1] + dp[i-2];}return dp[n];
}

正确答案:错误

10、有一排香蕉,每个香蕉有不同的甜度值。小猴子想吃香蕉,但不能吃相邻的香蕉。以下代码能找到小猴子吃到最甜的香蕉组合。

// bananas:香蕉的甜度
void findSelectedBananas(vector<int>& bananas, vector<int>& dp) {vector<int> selected;int i = bananas.size() - 1;while (i >= 0) {if (i == 0) {selected.push_break;back(0);}if (dp[i] == dp[i-1]) {i--;} else {selected.push_back(i);i -= 2;}}reverse(selected.begin(), selected.end());cout << "小猴子吃了第: ";for (int idx : selected)cout << idx+1 << " ";cout << "个香蕉" << endl;
}
int main() {vector<int> bananas = {1, 2, 3, 1}; // 每个香蕉的甜vector<int> dp(bananas.size());dp[0] = bananas[0];dp[1] = max(bananas[0], bananas[1]);for (int i = 2; i < bananas.size(); i++) {dp[i] = max(bananas[i] + dp[i-2], dp[i-1]);}findSelectedBananas(bananas, dp);return 0;
}

正确答案:正确

编程题 (每题 25 分,共 50 分)

划分字符串

【问题描述】
小 A 有一个由n个小写字母组成的字符串s。他希望将s划分为若干个子串,使得子串中每个字母至多出现一次。例如,对于字符串 street 来说, str + e + e + t 是满足条件的划分;而 s + tree + t 不是,因为子串tree 中 e 出现了两次。
额外地,小 A 还给出了价值a1,a2,...,ana_1, a_2, ..., a_na1,a2,...,an,表示划分后长度为i的子串价值为aia_iai。小A希望最大化划分后得到的子串价值之和。你能帮他求出划分后子串价值之和的最大值吗?
【输入格式】
第一行,一个正整数n,表示字符串的长度。
第二行,一个包含n个小写字母的字符串s。
第三行,n个正整数a1,a2,...,ana_1, a_2, ..., a_na1,a2,...,an,表示不同长度的子串价值。
【输出格式】
一行,一个整数,表示划分后子串价值之和的最大值。
【样例输入 1】
6
street
2 1 7 4 3 3
【样例输出 1】
13
【样例输入 2】
8
blossoms
1 1 2 3 5 8 13 21
【样例输出 2】
8
【数据范围】
对于40% 的测试点,保证1≤n≤1031 \le n \le 10^31n103
对于所有测试点,保证1≤n≤105,1≤ai≤1091 \le n \le 10^5, 1 \le a_i \le 10^91n105,1ai109

货物运输

【问题描述】
A 国有n座城市,依次以1,2,…,n编号,其中1号城市为首都。这n座城市由n-1条双向道路连接,第i条道路(1≤i<n)(1 \le i < n)1i<n连接编号为ui,viu_i, v_iui,vi的两座城市,道路长度为lil_ili。任意两座城市间均可通过双向道路到达。
现在 A 国需要从首都向各个城市运送货物。具体来说,满载货物的车队会从首都开出,经过一座城市时将对应的货物送出,因此车队需要经过所有城市。A 国希望你设计一条路线,在从首都出发经过所有城市的前提下,最小化经过的道路长度总和。注意一座城市可以经过多次,车队最后可以不返回首都。
【输入格式】
第一行,一个正整数n,表示 A 国的城市数量。
接下来n-1行,每行三个整数ui,vi,liu_i, v_i, l_iui,vi,li,表示一条双向道路连接编号为ui,viu_i, v_iui,vi的两座城市,道路长度为lil_ili
【输出格式】
一行,一个整数,表示你设计的路线所经过的道路长度总和。
【样例输入 1】
4
1 2 6
1 3 1
3 4 5
【样例输出 1】
18
【样例输入 2】
7
1 2 1
2 3 1
3 4 1
7 6 1
6 5 1
5 1 1
【样例输出 2】
9
【数据范围】
对于30% 的测试点,保证1≤n≤81 \le n \le 81n8
对于另外30% 的测试点,保证仅与一条双向道路连接的城市恰有两座。
对于所有测试点,保证1≤n≤105,1≤ui,vi≤n,1≤li≤1091 \le n \le 10^5, 1 \le u_i, v_i \le n, 1 \le l_i \le 10^91n105,1ui,vin,1li109

http://www.dtcms.com/a/453697.html

相关文章:

  • libopenssl-1_0_0-devel-1.0.2p RPM 包安装教程(openSUSE/SLES x86_64)​
  • 网站开发栏目需求1仪征网站建设公司哪家好
  • FK 外键上需要创建index 避免 主表update时 的lock
  • 三剑合璧:C++11 lambda、variadic template 与 wrapper 的协奏
  • 空间智能找文献方向
  • 儒枫网网站建设惠州 企业网站建设
  • 基于 GEE 平台用 Sentinel-1 SAR 数据实现山区潜在滑坡检测
  • CSS是什么?—— 网页的“化妆师”
  • cygwin + redis
  • 我也来做外国网站购物苏州新区建网站
  • #智能电饭煲技术开发原理与源代码实现
  • 无人机系统耗电,低功耗管理问题解决方法(chatgpt)
  • 设计网站国外公共建设工程中心网站
  • 第二十章:遍历万象,操作随心——Visitor的访问艺术
  • 找不到或无法加载主类
  • XMedia Recode:音频格式转换
  • Linux 内核态和用户态
  • 145、【OS】【Nuttx】【周边】效果呈现方案解析:VSCode Remote Server
  • 【C++实战(78)】解锁C++ 大数据处理:从并行到分布式实战
  • 农安县住房和城乡建设厅网站青岛网站建设开发
  • 建设网站企业邮箱查找
  • OpenCV(三):保存文件
  • 写一个shel脚本 完全备份 然后每天增量备份 以及计划任务 一周 mysql 数据库
  • 三好街做网站的微信企业网站源码下载
  • 车载诊断架构 --- 车载ECU故障类型详解(中)
  • 网站建设实训记录wordpress显示用户角色
  • 无人机系统耗电,低功耗管理问题解决方法(腾讯元宝)
  • 响应式网站建设公司好的建设网站公司
  • 刘火良 FreeRTOS内核实现与应用之13——内存管理、中断管理
  • 从“拉取请求“到“合并请求“:一个有趣的术语翻译现象