华为OD机试 C++【 最接近的数】

给定一个正整数数组X和整数K,需找到数组中使(X[i] - X[i + 1] - ... - X[i + K - 1])与中位数最接近的i值。当结果相同时,返回最大i。例如,对于输入[50, 50, 2, 3]和K=2,经过排序和计算,发现X[1] - X[2]最接近中位数50,故返回1。" 126923207,10897286,火车票业务解析:OTA平台如何介入,"['旅游', '在线旅行服务', '交通出行', '互联网业务', '票务系统']

题目

任务:
假设你有一个正整数数组X和一个整数K。请计算下式的结果:

X[i] - X[i + 1] - … - X[i + K - 1]

你的目标是找到使这个结果与数组的中位数最为接近的i值。如果有多个相同的结果,请返回最大的i。

额外信息:

数组的中位数是什么?当你把数组从小到大排序后,中间那个数字就是中位数。
你可以假设数组X里的元素都是正整数。
数组X的长度n限制为:2 ≤ n ≤ 1000。
K的值肯定小于数组的大小。
i的范围是:0 ≤ i < 1000。
例子:
输入: [50,50,2,3], 2
输出: 1

为什么?首先,这个数组排序后为[2,3,50,50],中位数是50。接着,我们按照上面的公式计算,找到差值与50最接近的是X[1] - X[2],所以返回1。

代码

#include <iostream>
#
### 华为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、付费专栏及课程。

余额充值