常规解法(时空复杂度都是O(n))

复制代码
class Solution {
    public int[] exchange(int[] nums) {
        int[] b=new int[nums.length];
        int k=0;
        for(int i=0;i<nums.length;i++)
        {
            if(nums[i]%2==1)
            {
                b[k++]=nums[i];

            }
            

        }
        for(int i=0;i<nums.length;i++)
        {
            if(nums[i]%2==0)
            {
                b[k++]=nums[i];
            }
        }
        return b;
    }
}
复制代码

 

 

 

 

快排思想解法(空间复杂度节省了)

复制代码
class Solution {
    public int[] exchange(int[] nums) {
        int i=0,j=nums.length-1;
        while(i<j)
        {
            int temp;

            while(i<j&&nums[i]%2==1)i++;
            while(i<j&&nums[j]%2==0)j--;
            temp=nums[i];
            nums[i]=nums[j];
            nums[j]=temp;


        }
        return nums;
    }
}
复制代码

 

posted on   upupup-999  阅读(44)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!



点击右上角即可分享
微信分享提示