刷题--调整数组顺序使奇数位于偶数前
来源:互联网 发布:java gui聊天程序 编辑:程序博客网 时间:2024/06/05 18:28
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
void reOrderArray(vector<int> &array) {vector<int> odds;//存放所有基数的数组,可以保证相对位置不变vector<int> even;for (int i = 0; i < array.size(); i++){if (array[i] % 2 != 0)odds.push_back(array[i]);else if (array[i] % 2 == 0)even.push_back(array[i]);}for (int i = 0; i < odds.size(); i++)//将基数倒回原来数组中array[i] = odds[i];for (int i = 0; i < even.size(); i++)//将偶数按照顺序放到最后 array[odds.size()+i] =even[i];}
若相对位置没有规定的话;
bool iseven(int n){return (n & 1) == 0;//若n为偶数,返回0}void reOrderArray1(vector<int> &array) {if (array.size() == 0 || array.empty())return;int pbegin =0;int pend =array.size()-1;while (pbegin < pend){while (pbegin < pend && !iseven(array[pbegin]))pbegin++;while (pbegin < pend && iseven(array[pend]))pend--;if (pbegin < pend)swap(array[pbegin], array[pend]);}}
阅读全文
0 0
- 刷题--调整数组顺序使奇数位于偶数前
- 程序员面试题精选——调整数组顺序使奇数位于偶数前
- 面试题12:调整数组顺序使奇数位于偶数前
- 【PHP】调整数组顺序使奇数位于偶数前(闭包扩展)
- 【数组3】-调整数组顺序使奇数位于偶数前面
- 数组3:调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面--总结
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面[
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 调整数组顺序使奇数位于偶数前面
- 仿iReader 阅读器(swift)
- Java中String字符串比较面试题
- YOLOV2参数详解
- 核心连接地址
- LeetCode-561 Array Partition I
- 刷题--调整数组顺序使奇数位于偶数前
- 反射的学习笔记
- c# 动态数组ArrayList
- 常用mysql命令
- 17年第二届计算机通信与计算机科学国际会议
- 大话设计模式阅读笔记-开发-封闭原则
- Spring之Bean容器初始化以及bean实例的获取
- 系统调用的实现原理
- Less入门和使用