华为OD机试 C++【按最低位排序的数组】

题目

给定一个非空数组(列表),其元素数据类型为整型,请按照数组元素十进制最低位从小到大进行排序,十进制最低位相同的元素,相对位置保持不变。当数组元素为负值时,十进制最低位等同于去除符号位后对应十进制值最低位。

输入描述
给定一个非空数组,其元素数据类型为32位有符号整数,数组长度[1, 1000]

输出描述
输出排序后的数组

用例

输入
1,2,5,-21,22,11,55,-101,42,8,7,32
输出	
1,-21,11,-101,2,22,42,32,5,55,7,8

解题思路

读取用户输入的数组,并将输入字符串按逗号分割成字符串数组,然后将其转换为整型数组。
使用 sort 方法和自定义比较器对数组进行排序。自定义比较器通过取每个整数的绝对值,并计算其最低位进行比较。

代码

#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]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

AlgorithmHero

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

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

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

打赏作者

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

抵扣说明:

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

余额充值