栏目分类:
子分类:
返回
文库吧用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
文库吧 > IT > 软件开发 > 后端开发 > Java

LeetCode(剑指 Offer)- 21. 调整数组顺序使奇数位于偶数前面

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LeetCode(剑指 Offer)- 21. 调整数组顺序使奇数位于偶数前面

题目链接:点击打开链接

题目大意:略

解题思路:略

相关企业

  • 字节跳动

AC 代码

  • Java
// 解决方案(1)
class Solution {
    public int[] exchange(int[] nums) {
        int len = nums.length;
        List l1 = new ArrayList<>();
        List l2 = new ArrayList<>();
        for (int i = 0; i < len; i++) {
            if (nums[i] % 2 != 0) {
                l1.add(nums[i]);
            } else {
                l2.add(nums[i]);
            }
        }
        l1.addAll(l2);
        int[] rs = new int[len];
        for (int i = 0; i < l1.size(); i++) {
            rs[i] = l1.get(i);
        }
        return rs;
    }
}

// 解决方案(2)
class Solution {
    public int[] exchange(int[] nums) {
        int i = 0, j = nums.length - 1, tmp;
        while(i < j) {
            while(i < j && (nums[i] & 1) == 1) i++;
            while(i < j && (nums[j] & 1) == 0) j--;
            tmp = nums[i];
            nums[i] = nums[j];
            nums[j] = tmp;
        }
        return nums;
    }
}
  • C++
class Solution {
public:
    vector exchange(vector& nums)
    {
        int i = 0, j = nums.size() - 1;
        while (i < j)
        {
            while(i < j && (nums[i] & 1) == 1) i++;
            while(i < j && (nums[j] & 1) == 0) j--;
            swap(nums[i], nums[j]);
        }
        return nums;
    }
};
转载请注明:文章转载自 www.wk8.com.cn
本文地址:https://www.wk8.com.cn/it/1040101.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 wk8.com.cn

ICP备案号:晋ICP备2021003244-6号