按奇偶排序数组

给定一个非负整数数组 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] 也会被接受。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sort-array-by-parity-ii

法一:

class Solution:
    def sortArrayByParityII(self, A: List[int]) -> List[int]:
        a= [0]*len(A)
        cnt0 = 0
        cnt1 = 1
        for i in A:
            if(i%2 == 0):
                a[cnt0] = i
                cnt0+=2
            else:
                a[cnt1] = i
                cnt1 += 2
        return a

在这里插入图片描述
创建一个和A等大的数组a,遍历,若A中为偶数填在a的偶数位上,反之填入奇数位。
法二:

class Solution:
    def sortArrayByParityII(self, A: List[int]) -> List[int]:
        ji=[]
        ou=[]
        for i in A:
            if i%2 == 0:
                ou.append(i)
            else:
                ji.append(i)
        a = []
        for i in range(len(A)):
            if(i%2==0):
                a.append(ou[i//2])
            else:
                a.append(ji[i//2])
        return a

在这里插入图片描述

蛮蠢的法…先把奇数偶数分开,在单独加入新列表,总体思路大概差不多,算是法一的劣化版吧…反正过60%了,不方不方

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用以下的方法来实现C语言数组元素的奇偶排序: 1. 遍历数组,找出所有的奇数偶数,并分别存放在两个新的数组中。 2. 对两个新的数组进行排序,可以使用冒泡排序、插入排序或者快速排序排序算法。 3. 将两个排序后的数组合并成一个新的数组,即先将奇数数组的元素复制到新数组中,再将偶数数组的元素复制到新数组的末尾。 4. 最后,新的数组中的元素就是按照奇偶排序的结果。 以下是一个示例代码: ```c #include <stdio.h> // 交换两个元素的值 void swap(int* a, int* b) { int temp = *a; *a = *b; *b = temp; } // 冒泡排序 void bubbleSort(int arr[], int size) { for (int i = 0; i < size - 1; i++) { for (int j = 0; j < size - i - 1; j++) { if (arr[j] > arr[j + 1]) { swap(&arr[j], &arr[j + 1]); } } } } int main() { int arr[] = { 3, 1, 4, 2, 5, 6 }; int size = sizeof(arr) / sizeof(arr[0]); int odd[size], even[size]; int oddCount = 0, evenCount = 0; // 将奇数偶数分别存放在两个数组中 for (int i = 0; i < size; i++) { if (arr[i] % 2 == 0) { even[evenCount++] = arr[i]; } else { odd[oddCount++] = arr[i]; } } // 对两个数组进行排序 bubbleSort(odd, oddCount); bubbleSort(even, evenCount); // 合并两个数组 int merged[size]; for (int i = 0; i < oddCount; i++) { merged[i] = odd[i]; } for (int i = 0; i < evenCount; i++) { merged[oddCount + i] = even[i]; } // 打印排序后的结果 for (int i = 0; i < size; i++) { printf("%d ", merged[i]); } return 0; } ``` 该代码首先将原始数组中的奇数偶数分别存放在两个新的数组中,然后对这两个数组进行排序。最后,将排序后的奇数数组偶数数组合并成一个新的数组,并打印出排序后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值