华为OD机试 C++【算力分配】

该博客介绍了一道华为在线开发者(OD)考试中的C++编程题,目标是通过交换两组服务器中的一对CPU来使两组服务器的算力相等,要求从A组选择的CPU算力尽可能小。解题思路包括计算算力差值,遍历A组并寻找匹配的B组CPU。

题目

现有两组服务器A和B,每组有多个算力不同的CPU,其中 A[i] 是 A 组第 i 个CPU的运算能力,B[i] 是 B组 第 i 个CPU的运算能力。
一组服务器的总算力是各CPU的算力之和。
为了让两组服务器的算力相等,允许从每组各选出一个CPU进行一次交换,
求两组服务器中,用于交换的CPU的算力,并且要求从A组服务器中选出的CPU,算力尽可能小。

输入描述
第一行输入为L1和L2,以空格分隔,L1表示A组服务器中的CPU数量,L2表示B组服务器中的CPU数量。
第二行输入为A组服务器中各个CPU的算力值,以空格分隔。
第三行输入为B组服务器中各个CPU的算力值,以空格分隔。
1 ≤ L1 ≤ 10000
1 ≤ L2 ≤ 10000
1 ≤ A[i] ≤ 100000
1 ≤ B[i] ≤ 100000

输出描述
对于每组测试数据,输出两个整数,以空格分隔,依次表示A组选出的CPU算力,B组选出的CPU算力。
要求从A组选出的CPU的算力尽可能小。

用例

输入	
2 2
1 1
2 2
输出	
1 2

解题思路

计算两组服务器的总算力差值。然后,遍历A组服务器中的每个CPU,通过差值计算出在B组中对应的CPU算力值。接着,检查是否存在这样的算力值,若存在则输出对应的两个CPU算力值,完成交换。

代码

### 华为ODC++考点与练习 华为OD中,C++作为一门重要的编程语言,其考点覆盖了基础语法、数据结构、法设计以及代码优化等多个方面。以下是C++华为OD中的主要考点相关题目练习[^1]。 #### 1. C++基础语法 C++的基础语法是考察的重点之一,包括变量声明、数据类型、运符、控制结构等。例如: - **变量与数据类型**:熟悉`int`、`float`、`double`、`char`等基本数据类型的使用。 - **运符**:掌握术运符、关系运符、逻辑运符的优先级及用法。 - **控制结构**:熟练使用`if-else`、`switch-case`、`for`、`while`等语句进行程序逻辑控制。 示例代码: ```cpp #include <iostream> using namespace std; int main() { int a = 10, b = 20; if (a > b) { cout << "a is greater than b" << endl; } else { cout << "b is greater than or equal to a" << endl; } return 0; } ``` #### 2. 函数与指针 函数指针是C++的核心概念之一,也是中常见的考点。 - **函数定义与调用**:掌握函数参数传递(值传递、引用传递)、返回值类型等。 - **指针操作**:理解指针的基本概念及其在内存管理中的应用。 示例代码: ```cpp #include <iostream> using namespace std; void swap(int* a, int* b) { int temp = *a; *a = *b; *b = temp; } int main() { int x = 5, y = 10; swap(&x, &y); cout << "x: " << x << ", y: " << y << endl; return 0; } ``` #### 3. 面向对象编程 C++支持面向对象编程(OOP),这是华为OD的重要部分。 - **类与对象**:熟悉类的定义、成员函数、构造函数、析构函数等。 - **继承与多态**:掌握继承制、虚函数、多态性的实现。 示例代码: ```cpp #include <iostream> using namespace std; class Animal { public: virtual void sound() { cout << "Animal makes a sound" << endl; } }; class Dog : public Animal { public: void sound() override { cout << "Dog barks" << endl; } }; int main() { Animal* animal = new Dog(); animal->sound(); // 输出 "Dog barks" delete animal; return 0; } ``` #### 4. 数据结构与华为ODC++的数据结构法要求较高,以下是一些常见考点: - **数组与字符串**:数组的操作、字符串处理(如子串查找、反转字符串等)。 - **链表**:单链表、双链表的创建、遍历、插入、删除等操作。 - **栈与队列**:栈队列的基本操作及应用场景。 - **排序与查找**:快速排序、归并排序、二分查找等经典法。 示例代码(快速排序): ```cpp #include <iostream> using namespace std; void quickSort(int arr[], int left, int right) { if (left >= right) return; int pivot = arr[(left + right) / 2]; int i = left, j = right; while (i <= j) { while (arr[i] < pivot) i++; while (arr[j] > pivot) j--; if (i <= j) { swap(arr[i], arr[j]); i++; j--; } } if (left < j) quickSort(arr, left, j); if (right > i) quickSort(arr, i, right); } int main() { int arr[] = {5, 3, 8, 6, 2}; int n = sizeof(arr) / sizeof(arr[0]); quickSort(arr, 0, n - 1); for (int i = 0; i < n; i++) { cout << arr[i] << " "; } return 0; } ``` #### 5. STL库的应用 C++标准模板库(STL)提供了丰富的容器、函数,能够简化代码编写。以下是常用的部分: - **容器**:`vector`、`list`、`map`、`set`等。 - **法**:`sort`、`find`、`reverse`等。 示例代码: ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; int main() { vector<int> vec = {5, 3, 8, 6, 2}; sort(vec.begin(), vec.end()); for (auto num : vec) { cout << num << " "; } return 0; } ``` ### 练习建议 为了更好地准备华为OD,建议通过以下方式提升C++: 1. 使用在线OJ平台(如LeetCode、牛客网等)进行刷题,选择C++语言进行练习。 2. 针对自己薄弱的知识点进行专项训练,逐步提高。 3. 模拟真实考环境,限时完成题目以锻炼解题速度准确性[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AlgorithmHero

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值