LeetCode 922. 按奇偶排序数组 II
922. 按奇偶排序数组 II
难度简单
给定一个非负整数数组 A
, A 中一半整数是奇数,一半整数是偶数。
对数组进行排序,以便当 A[i]
为奇数时,i
也是奇数;当 A[i]
为偶数时, i
也是偶数。
你可以返回任何满足上述条件的数组作为答案。
示例:
输入:[4,2,5,7] 输出:[4,5,2,7] 解释:[4,7,2,5],[2,5,4,7],[2,7,4,5] 也会被接受。
提示:
2 <= A.length <= 20000
A.length % 2 == 0
0 <= A[i] <= 1000
思路一:开辟两个空间,一个放奇数,一个放偶数,然后将A重新赋值。
1 int* sortArrayByParityII(int* A, int ASize, int* returnSize){ 2 int i,m=0,n=0; 3 int *B,*C; 4 B=(int *)malloc((ASize/2)*sizeof(int)); 5 C=(int *)malloc((ASize/2)*sizeof(int)); 6 for(i=0;i<ASize;i++){ 7 if(A[i]%2==0){ 8 B[m++]=A[i]; 9 }else{ 10 C[n++]=A[i]; 11 } 12 } 13 m=0; 14 n=0; 15 for(i=0;i<ASize;i++){ 16 if(i%2==0){ 17 A[i]=B[m++]; 18 }else{ 19 A[i]=C[n++]; 20 } 21 } 22 *returnSize=ASize; 23 return A; 24 }
方法二:双指针,一次遍历,偶指针遇到奇数,用奇指针找到一个偶数,对换。
1 int* sortArrayByParityII(int* A, int ASize, int* returnSize){ 2 int i,j=1,temp; 3 for(i=0;i<ASize;i+=2){ 4 if(A[i]%2==1){ 5 while(A[j]%2==1){ 6 j+=2; 7 } 8 temp=A[i]; 9 A[i]=A[j]; 10 A[j]=temp; 11 } 12 } 13 *returnSize=ASize; 14 return A; 15 }