剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面
题目:输入一个整数数组。实现一个函数来调整该数组中数字的顺序。使得全部奇数位于数组的前半部分。全部偶数位于数组的后半部分。
1、基本实现:
假设不考虑时间复杂度,最简单的思路应该是从头扫描这个数组,每碰到一个偶数时,拿出这个数字,并把位于这个数字后面的全部的数字往前面挪动一位。
挪完之后在数组的末尾有一个空位。这时把该偶数放入这个空位。
因为没碰到一个偶数就须要移动O(n)个数字。因此总的时间复杂度是O(n2).可是,这样的方法不能让面试官惬意。只是假设我们在听到题目之后立就可以以说出这个解法,面试官至少会认为我们的思维很灵敏。
2、仅仅完毕基本功能的解法,仅适用于0基础程序猿
这个题目要求把奇数放在数组的前半部分。偶数放在数组的后半部分。因此全部的奇数应该位于偶数的前面,也就是说我们在扫描这个数组的时候,假设发现有偶数在奇数的前面,我们能够交换他们的数序,交换之后就符合要求了。
因此我们能够维护两个指针,第一个指针初始化时指向数组的第一个数字,它仅仅向后移动。第二个指针初始化时指向数组的最后一个数字。它指向前移动。在两个指针相遇之前,第一个指针总是位于第二个指针的前面。假设第一个指针的数字是偶数,而且第二个指针指向的数字是奇数,我们就交换两个数字。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
3、考虑可扩展性的解法。秒杀Offer
假设是面试应届毕业生或者工作时间不长的程序猿。面试官会惬意前面的代码。但假设应聘者申请的是资深的开发职位。那面试官可能会接着问几个问题。
面试官:假设把题目改成数组中的数依照大小分为两部分,全部的负数在全部的非负数的前面,该怎么做?
假设再把题目改改,变成 把数组中的数分成两部分,能被3整除的数都在不能被3整除的数的前面。怎么办?
这就是面试官在考察我们对可扩展性的理解。即希望我们可以给出一个模式,在这个模式下可以非常方面第把已有的解决方式扩展到同类型的问题上去。
于是我们写出以下的代码:
/**
* 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得全部奇数位于数组的前半部分,全部的偶数位于数组的后半部分
*/
package swordForOffer; /**
* @author JInShuangQi
*
* 2015年8月1日
*/
public class E14ReorderArray {
public void order(int[] arr){
if(arr == null)
return;
int i = 0;
int j = arr.length-1;
while(i<j){
if(isEven(arr[i]) && !isEven(arr[j])){
int temp = arr[i];
arr[i]= arr[j];
arr[j] = temp;
}
else if(!isEven(arr[i]) && isEven(arr[j])){
i++;
}
else if(isEven(arr[i]) && isEven(arr[j])){
j--;
}else{
i++;
j--;
}
}
}
public boolean isEven(int n){
return (n & 1) == 0;
}
public static void main(String[] args){
E14ReorderArray test = new E14ReorderArray();
int[] arr= {1,2,3,4,5,6,12,7,8,9,10};
test.order(arr);
for(int i = 0;i<arr.length ;i++){
System.out.print(arr[i]+",");
}
}
}
剑指offer面试题14(Java版):调整数组顺序使奇数位于偶数的前面的更多相关文章
- 《剑指offer》第二十一题(调整数组顺序使奇数位于偶数前面)
// 面试题21:调整数组顺序使奇数位于偶数前面 // 题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有 // 奇数位于数组的前半部分,所有偶数位于数组的后半部分. #inclu ...
- 《剑指offer》— JavaScript(13)调整数组顺序使奇数位于偶数前面
调整数组顺序使奇数位于偶数前面 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的 ...
- 【Java】 剑指offer(21) 调整数组顺序使奇数位于偶数前面
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇 ...
- 【剑指Offer面试题】 九度OJ1516:调整数组顺序使奇数位于偶数前面
题目链接地址: http://ac.jobdu.com/problem.php?pid=1516 题目1516:调整数组顺序使奇数位于偶数前面 时间限制:1 秒内存限制:128 兆特殊判题:否提交:2 ...
- 【剑指offer】面试题 21. 调整数组顺序使奇数位于偶数前面
面试题 21. 调整数组顺序使奇数位于偶数前面
- 剑指Offer:调整数组顺序使奇数位于偶数前面【21】
剑指Offer:调整数组顺序使奇数位于偶数前面[21] 题目描述 输入一个整形数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 解题分析 使用插 ...
- 剑指offer:调整数组顺序使奇数位于偶数前面
题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 分析 事实上,这个题比较简单,很多种方式都可以实现,但是其时间复杂度或空间复 ...
- 剑指Offer - 九度1516 - 调整数组顺序使奇数位于偶数前面
剑指Offer - 九度1516 - 调整数组顺序使奇数位于偶数前面2013-11-30 02:17 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部 ...
- 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 Offer 21 这题的解法其实是考察快慢指针和头尾指针. package com.walegarrett.offer; /** * @Aut ...
- 调整数组顺序使奇数位于偶数前面 牛客网 剑指Offer
调整数组顺序使奇数位于偶数前面 牛客网 剑指Offer 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇 ...
随机推荐
- jupyter在特定环境特定目录中启动
代码如下: @echo off start %windir%\System32\cmd.exe "/c" D:\Anaconda\Scripts\activate.bat # 启动 ...
- 关于chm提示 已取消到该网页的导航的解决方法
下载了一个chm文件,打开提示“已取消到该网页的导航”,以前以为是文件有问题,下载其他的也是出现这种情况,于是网上搜了下,解决方法如下: 方法 1 1. 双击此 .chm 文件. 2. 在“打开文件安 ...
- [XJOI]noip40 T2统计方案
统计方案 小B写了一个程序,随机生成了n个正整数,分别是a[1]..a[n],他取出了其中一些数,并把它们乘起来之后模p,得到了余数c.但是没过多久,小B就忘记他选了哪些数,他想把所有可能的取数方案都 ...
- [ Java ] [ JUnit ] [ Eclipse ] coverage
官方資訊: https://www.eclemma.org/ - 簡短使用範例說明: https://dzone.com/articles/java-code-coverage-in-eclipse ...
- 7 Python+Selenium浏览器设置
[环境信息] python3.6+selenium3.0.2+Firefox50.0+win7 [浏览器设置方法] 1.浏览器最大化:maximize_window() 2.设置浏览器宽.高:set_ ...
- 杭电1159 Common Subsequence【最长公共子序列】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1159 解题思路:任意先给出两个字符串 abcfbc abfcab,用dp[i][j]来记录当前最长的子 ...
- 关于ZBrush中Subtool的小秘密
想问大家一个问题,你们刚开始学习ZBrush 3D图形绘制软件的时候,是不是特别迷茫?有没有人和小编一样,一直以为ZBrush中的Subtools就相当于Layers呢? 经过长时间的实践之后,小编才 ...
- 插入排序InsertSort
插入排序:从第二个数开始 一直和前面的数组比较 获得排序定位 代码 /** *插入排序 */ public class InsertSort { public static void inser ...
- day25-3 json,pickle模块
目录 json 序列化 反序列化 pickle json json文件并不是python独有的,所有的语言都有json,可以跨平台/语言传输数据 json文件中只能写入python中的dict/lis ...
- POI操作Excel的三种Workbook的发展和区别
POI的一些使用方法: 创建流程:(上级为下级的载体) 1.创建Workbook(工作薄): 2.创建Sheet(表单,可以创建多个): 3.创建Row(行): 4.创建Cell(单元格) 接下来分别 ...