我正在尝试解决一个问题,例如...在数组中,我们必须将所有奇数元素移到开头...偶数元素到结尾...我尝试过这种方式,但是偶数在这里失去了顺序...可以谁来帮帮我 ???????我得到的输出是 ...1 3 5 7 9 4 8 2 6
期望线性时间解决方案...
#include<stdio.h>
void swap(int *p,int *q)
{
*p=*p^*q;
*q=*p^*q;
*p=*p^*q;
}
int main()
{
int arr[]={ 2, 1 ,4 ,3 ,6 ,5 ,8 ,7 ,9};
int odd=0;
int even=0;
int arr_size = sizeof(arr)/sizeof(arr[0]);
while(even< arr_size){
if(arr[even]&1)
swap(&arr[odd++],&arr[even++]);
else
even++;
}
int i=0;
for(i=0;i<arr_size ;i++)
printf("%d ",arr[i]);
return 0;
}