题目:
输入一个整数数组,实现一个函数来调整该数组中数组的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。
解法一: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]);//交换 } }
时间: 2024-11-10 07:35:50