剑指Offer:调整数组顺序使奇数位于偶数前面
来源:互联网 发布:命令提示符编译java 编辑:程序博客网 时间:2024/05/23 11:47
调整数组顺序使奇数位于偶数前面
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
class Solution {public: void reOrderArray(vector<int> &array) { int sz=array.size(); while(isfin(array,sz)){ for(int i=0;i<sz;++i){ if(array[i]&1){//寻找奇数 for(int j=i;j>=0;--j){ if(!(array[j]&1)){//将奇数与前面最近的偶数替换 swap(array[i],array[j]); break; } } } } } }private: bool isfin(vector<int> &array,int &sz){ for(int i=1;i<sz;++i){ if((!(array[i-1]&1))&&(array[i]&1)) return true;//偶数、奇数 } return false; }};
2016.9.10更新
类似于插入排序。从后往前,遇到偶数就往后交换,将本奇数插入到前面最近的奇数后,
class Solution {public: void reOrderArray(vector<int> &array) { if(array.empty()) return; size_t sz=array.size(); for(size_t i=1;i<sz;++i){ if(help(array[i])){ //size_t无符号整型,处理判断条件要注意点 for(size_t j=i;j>0&&(!help(array[j-1]));--j){ swap(array[j-1],array[j]); } } } }private: bool help(const int &val){ return val&1; }};
0 0
- 剑指offer:调整数组顺序使奇数位于偶数前面
- 剑指offer--调整数组顺序使奇数位于偶数前面
- 剑指offer 调整数组顺序使奇数位于偶数前面
- 《剑指offer》调整数组顺序使奇数位于偶数前面
- 剑指 offer:调整数组顺序使奇数位于偶数前面
- 剑指offer-调整数组顺序使奇数位于偶数前面
- 剑指offer 调整数组顺序使奇数位于偶数前面
- 剑指offer-调整数组顺序使奇数位于偶数前面
- 剑指offer 调整数组顺序使奇数位于偶数前面
- 【剑指offer】调整数组顺序使奇数位于偶数前面
- [剑指offer]调整数组顺序使奇数位于偶数前面
- 剑指offer:调整数组顺序使奇数位于偶数前面
- 【剑指offer】调整数组顺序使奇数位于偶数前面
- 剑指offer|调整数组顺序使奇数位于偶数前面
- 《剑指offer》调整数组顺序使奇数位于偶数前面
- 剑指Offer:调整数组顺序使奇数位于偶数前面
- 剑指offer - 调整数组顺序使奇数位于偶数前面
- 【剑指offer】调整数组顺序使奇数位于偶数前面
- 反调试技巧总结-原理和实现
- POJ 3259 Wormholes Bellman判断是否有负环
- objective-c之多态
- Hbase 创建表出现异常 org.apache.hadoop.hbase.TableExist
- Spring学习笔记3:springmvc03 非注解和注解处理器映射器和适配器
- 剑指Offer:调整数组顺序使奇数位于偶数前面
- 线段树练习(3)hdu2795 Billboard
- 51Nod-1126-求递推序列的第N项
- POJ 3579 Median
- Android的第一个项目HelloWorld(疯狂Android讲义)
- 常用HTTP状态码
- 使用图片方式自定义iOS导航栏navigationItem的backBarButtonItem
- 概述
- Notes: Exceptions in Java(Java中的异常处理)