码迷,mamicode.com
首页 > 编程语言 > 详细

剑指offer 面试14—调整数组顺序使奇数位于偶数前面

时间:2015-04-29 19:49:15      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:剑指offer   调整数组顺序使奇数位于偶数前面   奇数位于偶数前面   

题目:

输入一个整数数组,实现一个函数来调整该数组中数组的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。


解法一:O(n^2)

从头扫描数组,每碰到一个偶数,拿出这个数字,并把位于这个数字后面的所有数字往前挪动一位。挪完之后在数组的末尾有一个空位,这时把该偶数放入这个空位中。

由于每碰到一个偶数就需要移动O(n)个数字,因此总的时间复杂度是O(n^2).


解法二:O(n)

类似快排,两个指针,一个指向数组头,只向后移动,一个指向数组尾,只向前移动。如果第一个指针指向的数字是偶数,并且第二个指针指向的数字是奇数,交换两数。


void foo(int a[],int left,int right)
{
    if(left>right)
       return;
    int i,j;
    i=left;
    j=right;
    while(i!=j)
    {
        while(a[j]%2==0&&i<j) j--;
        while(a[i]%2!=0&&i<j) i++;

        if(i<j)
             swap(a[i],a[j]);//交换
      }
}


剑指offer 面试14—调整数组顺序使奇数位于偶数前面

标签:剑指offer   调整数组顺序使奇数位于偶数前面   奇数位于偶数前面   

原文地址:http://blog.csdn.net/wtyvhreal/article/details/45370241

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!