剑指Offer_编程题(C#实现)_ 调整数组顺序使奇数位于偶数前面

博客介绍了如何在C#中调整整数数组,使得奇数位于前半部分,偶数位于后半部分,同时保持数字间的相对位置不变。提供了三种解题思路:一是通过构建新数组实现,二是利用List动态插入元素,三是通过移动元素实现。每种解法都有对应的详细说明和实现代码。
摘要由CSDN通过智能技术生成

题目:调整数组顺序使奇数位于偶数前面

题目描述

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。

解题思路

解法1

最直接的思路是再构建一个新数组,先遍历一遍原数组,把其中的奇数依次添加到新数组中,再遍历一遍原数组把其中的偶数依次添加到新数组中,时间复杂度为O(2n)。

解法2

C#的数组是不支持动态添加元素的,我们可以使用泛型List,来实现在指定位置插入元素。基本思路是遍历原数组,依次将元素插入到List中,如果是偶数元素,默认插入到List的末尾。如果是奇数元素,则插入到所有的偶数元素之前(已插入的所有奇数元素之后),因此需要记录最后插入的奇数元素的索引。算法的时间复杂度是O(n)。

解法3

基本思路是遍历原数组,如果遇到了奇数元素,就将该元素向前移动,该元素前面的偶数元素都依次向后移动。

参考代码

解法1

class Solution
{
    public int[] reOrderArray(int[] array)
    {
        // write code here
        int[] newArray = new int[array.Length];
        int j=0;
        f
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值