77.调整数组顺序使奇数位于偶数前面

知识点:数组;快速排序;冒泡排序;

题目描述

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

例如:

输入:1,2,3,4;     输出:1,3,2,4;
输入:2,4,6,5,7; 输出:5,7,2,4,6;
假设这个题我们没有最后一句话,也就是不用保持相对位置,只让奇数在前,偶数在后就可以了;

解法一:

遍历数组,遇到奇数的时候就把它前面的都向后移一位,然后让这个奇数位于最前面;

class Solution {
public int[] exchange(int[] nums) {
for(int i = 0; i < nums.length; i++){
if(nums[i] % 2 != 0){
int temp = nums[i];
for(int j = i; j > 0; j--){
nums[j] = nums[j-1];
}
nums[0] = temp;
}
}
return nums;
}
}

时间复杂度O(n^2);

解法二:快速排序的思想

试想一下快速排序,就是让小的在前,大的在后,这道题就是奇的在前,偶的在后,有点像啊。怎么做呢,前后各定义一个指针,前面的开始往后走,碰到偶数停下来,后面的往前走,碰到奇数停下来,然后把他俩换一下,当两个指针碰面了,那就结束了;

class Solution {
public int[] exchange(int[] nums) {
int left = 0;
int right = nums.length - 1;
while(left < right){
if(nums[left] % 2 != 0){
left++;
continue; //每次移动完后就出去看看俩人碰面没;
}
if(nums[right] % 2 == 0){
right--;
continue;
}
int temp = nums[left];
nums[left] = nums[right];
nums[right] = temp;
}
return nums; }
}

时间复杂度O(NlogN);

好了,前面是不用固定相对位置的时候我们的做法,现在不仅要让奇数在前,偶数在后,还要让他们原来的相对位置不能发生变化;

解法一:

从头到尾遍历一遍数组,然后找到奇数,把奇数依次存到我们新建的一个数组里,然后再从头到尾遍历一遍数组,找到偶数,把偶数再存进去;

import java.util.*;
public class Solution {
public int[] reOrderArray (int[] array) {
int[] ans = new int[array.length];
int index = 0;
for(int i = 0; i < array.length; i++){
if(array[i] % 2 == 1){
ans[index] = array[i];
index++;
}
}
for(int i = 0; i < array.length; i++){
if(array[i] % 2 == 0){
ans[index] = array[i];
index++;
}
}
return ans;
}
}

这种方法新建了一个数组,时间复杂度O(n);但是空间复杂度O(n);

解法二:冒泡排序思想

上面不保持相对位置的时候我们用了快速排序的思想,现在想想冒泡排序,其有一个很大的特点:冒泡具有稳定性,前后位置不会发生变化;

遍历整个数组,如果出现前偶后奇的情况,那就把他们交换位置,这样一轮下来,原始数组中最右边的那个偶数一定排到了最后一个。然后再接着来一轮....

public class Solution {
public int[] reOrderArray (int[] array) {
for(int i = 0; i < array.length; i++){
for(int j = 0; j < array.length - 1 - i; j++){
if(array[j] % 2 == 0 && array[j+1] % 2 == 1){
int temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
}
}
}
return array;
}
}

时间复杂度O(n^2),其实就是用时间换空间;

【剑指offer】77.调整数组顺序使奇数位于偶数前面的更多相关文章

  1. 剑指offer:调整数组顺序使奇数位于偶数前面

    题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 分析 事实上,这个题比较简单,很多种方式都可以实现,但是其时间复杂度或空间复 ...

  2. 剑指Offer:调整数组顺序使奇数位于偶数前面【21】

    剑指Offer:调整数组顺序使奇数位于偶数前面[21] 题目描述 输入一个整形数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 解题分析 使用插 ...

  3. 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面

    剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 Offer 21 这题的解法其实是考察快慢指针和头尾指针. package com.walegarrett.offer; /** * @Aut ...

  4. 【Java】 剑指offer(21) 调整数组顺序使奇数位于偶数前面

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇 ...

  5. 【剑指Offer】调整数组顺序使奇数位于偶数前面 解题报告(Python)

    [牛客网]调整数组顺序使奇数位于偶数前面 解题报告 标签(空格分隔): 牛客网 题目地址:https://www.nowcoder.com/questionTerminal/beb5aa231adc4 ...

  6. 剑指offer(07)-调整数组顺序使奇数位于偶数前面【转】

    来源:http://www.acmerblog.com/offer-6-2429/ 题目来自剑指offer系列 九度 1516 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得 ...

  7. Go语言实现:【剑指offer】调整数组顺序使奇数位于偶数前面

    该题目来源于牛客网<剑指offer>专题. 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和 ...

  8. 剑指OFFER之调整数组顺序使奇数位于偶数前面找(九度OJ1516)

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

  9. 剑指Offer 13. 调整数组顺序使奇数位于偶数前面 (数组)

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

  10. 【剑指offer】调整数组顺序使奇数位于偶数前面

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

随机推荐

  1. 闵可夫斯基引擎Minkowski Engine

    闵可夫斯基引擎Minkowski Engine Minkowski引擎是一个用于稀疏张量的自动微分库.它支持所有标准神经网络层,例如对稀疏张量的卷积,池化,解池和广播操作.有关更多信息,请访问文档页面 ...

  2. 【Javascript + Vue】实现对任意迷宫图片的自动寻路

    前言 可以直接体验最终效果:https://maze-vite.vercel.app/ 寻路前: 寻路后,自动在图片上生成红色路径,蓝色是探索过的区域: 这里我故意用手机斜着角度拍,就是为了展示程序完 ...

  3. fiddler选项卡-Statistc(统计)

    Statistc Statistc是fiddler用来对session列表里的Session相关情况的统计,利用这个选项,可以对请求进行性能以及其他数据分析 1.界面 2.参数详解 建议:打开fidd ...

  4. 关于JAVA的FlowLayout流动布局的换行问题--图形界面

    我在网上寻找Java流动布局换行的方法,看了好久,也没有找到满意的答案. FlowLayout是流式布局,所以如果需要让换行有意义,就得锁定窗口的大小,否则随着窗口的伸缩,布局将被彻底打乱. 网上的方 ...

  5. 深入理解java虚拟机笔记Chapter3-垃圾收集器

    垃圾收集器 垃圾收集(Garbage Collection,GC),它的任务是解决以下 3 件问题: 哪些内存需要回收? 什么时候回收? 如何回收? 本节补充知识: ① s:Survivor区 新生代 ...

  6. HashMap源码解析和设计解读

    HashMap源码解析 ​ 想要理解HashMap底层数据的存储形式,底层原理,最好的形式就是读它的源码,但是说实话,源码的注释说明全是英文,英文不是非常好的朋友读起来真的非常吃力,我基本上看了差不多 ...

  7. Filebrowser 安装简介

    官网地址: https://filebrowser.org https://github.com/filebrowser/filebrowser 官网安装方法: curl -fsSL https:// ...

  8. jmeter--JSON Extractor 用法

    JMeter处理大部分请求返回的结果,都是json.对于请求返回的结果,处理以后作为其他请求的参数,有一个方便使用的插件:JSON Extractor JSON Extractor中文叫做json提取 ...

  9. 【CMD】修改文件夹的属性

    将 d:\文件夹 添加 只读 属性: attrib +r d:\文件夹 /d 将 d:\文件夹 去掉 只读 属性: attrib -r d:\文件夹 /d 其他属性可以参考帮助文件:

  10. 搞清楚Spring事件机制后:Spring的源码看起来简单多了

    本文主讲Spring的事件机制,意图说清楚: 什么是观察者模式? 自己实现事件驱动编程,对标Spring的事件机制 彻底搞懂Spring中的事件机制,从而让大家 本文内容较长,代码干货较多,建议收藏后 ...