题解 | #调整数组顺序使奇数位于偶数前面#
调整数组顺序使奇数位于偶数前面
http://www.nowcoder.com/practice/ef1f53ef31ca408cada5093c8780f44b
剑指offer是只要求奇数在前,但是牛客网还加了一个要求:保证奇数和奇数,偶数和偶数之间的相对位置不变
剑指offer可以用双指针,一个指头,一个指尾,往中间走,奇偶兑换。
牛客网的解题思路,用一个新数组遍历两遍。
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param array int整型一维数组
* @return int整型一维数组
*/
public int[] reOrderArray (int[] array) {
int[] res = new int[array.length];
int index = 0;
for (int i = 0; i < array.length; i++) {
if (array[i] % 2 != 0) {
res[index++] = array[i];
}
}
for (int i = 0; i < array.length; i++) {
if (array[i] % 2 == 0) {
res[index++] = array[i];
}
}
return res;
}
}
查看2道真题和解析