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

C++:调整数组顺序使奇数位于偶数前面【面试】

在C++,如果要调整数组顺序使所有奇数位于偶数前面,这里提供一种简单且常用的方法:双指针技术。这种方法不需要额外的空间,并且时间复杂度为O(n)。

以下是使用双指针技术实现的示例代码:

#include <iostream>
#include <vector>
#include <algorithm> // 用于std::swapvoid rearrangeArray(std::vector<int>& nums) {int left = 0; // 奇数的起始指针int right = nums.size() - 1; // 偶数的起始指针while (left < right) {// 左指针向右移动,寻找第一个偶数while (left < right && nums[left] % 2 != 0) {++left;}// 右指针向左移动,寻找第一个奇数while (left < right && nums[right] % 2 == 0) {--right;}// 如果左右指针没有交错,交换两个数if (left < right) {std::swap(nums[left], nums[right]);++left;--right;}}
}int main() {std::vector<int> nums = {1, 4, 3, 6, 9, 2, 7, 8};rearrangeArray(nums);std::cout << "Array after rearrangement: ";for (int num : nums) {std::cout << num << " ";}return 0;
}

这段代码中,我们使用了两个指针leftright。初始时,left指向数组的开始,right指向数组的末尾。然后我们分别从左右两边向中间扫描:

  • left从左到右找到第一个偶数。
  • right从右到左找到第一个奇数。

找到之后,交换这两个数。然后继续这个过程,直到leftright相遇或交错。

这种方法保证了所有的奇数在数组的前半部分,偶数在后半部分,满足了题目要求。

面试回答示例:
"要解决这个问题,我们可以使用双指针技术。首先,我们初始化两个指针,一个指向数组的开始,另一个指向数组的末尾。然后,我们分别从数组的两端向中间扫描,左边的指针寻找偶数,右边的指针寻找奇数。一旦找到,我们就交换这两个数的位置。我们重复这个过程,直到两个指针交错或相遇。这种方法不需要额外的存储空间,并且时间复杂度为O(n),是一种高效且常用的解决方案。"

http://www.lryc.cn/news/370888.html

相关文章:

  • WPF/C#:程序关闭的三种模式
  • 登录/注册- 滑动拼图验证码(IOS/Swift)
  • MyBatis进行模糊查询时SQL语句拼接引起的异常问题
  • 网站调用Edge浏览器API:https://api-edge.cognitive.microsofttranslator.com/translate
  • css实现优惠券样式
  • 函数递归(C语言)(详细过程!)
  • uniapp 接口请求封装
  • C++中的观察者模式
  • conda虚拟环境,安装pytorch cuda cudnn版本一致,最简单方式
  • 第 5 章:面向生产的 Spring Boot
  • 在 Windows 操作系统中,可以通过命令行工具来杀死进程
  • uni-app文件下载 h5 xls 乱码 锟斤拷 Blob pdf打不开
  • Vue25-内置指令02:v-text指令
  • stable diffusion中的negative prompt是如何工作的
  • STM32项目分享:智能小区充电桩系统
  • PDU模块中浪涌保护模块与空开模块的应用
  • 19、Go Gin框架集成Swagger
  • 自动同步库数据——kettle开发36
  • MSOCache在电脑中可以删除吗?
  • 数据网格和视图入门
  • 雨的轮回与生命的律动
  • CANopen for Python 使用教程(二)
  • 前方碰撞缓解系统技术规范(简化版)
  • 数据赋能(117)——体系:数据收集——实施过程、应用特点
  • 【吃包子game】
  • 图片转Base64
  • STM32项目分享:智能家居语音系统
  • iOS 18 为 iPhone 15 机型引入了更多充电限制选项
  • Linux文本三剑客 awk 和 grep
  • Python NumPy 库详解