剑指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 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇 ...
 
随机推荐
- TestNG环境搭建以及框架初识
			
TestNG的英文为Test Next Generation, 听上去好像下一代测试框架已经无法正常命名了的样子,哈哈,言归正传,啥是TestNG呢,它是一套测试框架,在原来的Junit框架的思想基础 ...
 - poj 1161 Floyd+枚举
			
题意是: 给出n个点,围成m个区域.从区域到另一个区域间需穿过至少一条边(若两区域相邻)——边连接着两点. 给出这么一幅图,并给出一些点,问从这些点到同一个区域的穿过边数最小值. 解题思路如下: 将区 ...
 - MVC HtmlHelper扩展——实现分页功能
			
MVC HtmlHelper扩展类(PagingHelper) using System; using System.Collections.Generic; using System.Collect ...
 - Android之Action Bar
			
Action Bar在实际应用中,很好地为用户提供了导航,窗口位置标识,操作点击等功能.它出现于Android3.0(API 11)之后的版本中,在2.1之后的版本中也可以使用. 添加与隐藏Actio ...
 - Data内置对象
			
1.内置对象 Date 日期对象 2.创建日期对象 2.1 根据当前的系统时间来创建日期对象. var date1 = new Date(); //a.输出日期对象的信息 console.log(da ...
 - RedHat/CentOS 手动挂载磁盘
			
#创建挂载目录mkdir /mnt/sdamkdir /mnt/sdbmkdir /mnt/sdcmkdir /mnt/sddmkdir /mnt/sdemkdir /mnt/sdfmkdir /mn ...
 - Kafka学习笔记(7)----Kafka使用Cosumer接收消息
			
1. 什么是KafkaConsumer? 应用程序使用KafkaConsul'le 「向Kafka 订阅主题,并从订阅的主题上接收消息.Kafka的消息读取不同于从其他消息系统读取数据,它涉及了一些独 ...
 - 换个语言学一下 Golang (2)——基础语法
			
Go 标记 Go 程序可以由多个标记组成,可以是关键字,标识符,常量,字符串,符号.比如下面的hello world就是由 6 个标记组成: 行分隔符 在 Go 程序中,一行代表一个语句结束.每个语句 ...
 - MySQL数据库各个版本的区别
			
MySQL数据库各个版本的区别 MySQL数据库 MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),MySQL数据库系统使用最常用的数据库管理语言--结构化查询语言(SQL)进行数据库管 ...
 - python编写简单的html登陆页面(3)
			
1 在python编写简单的html登陆页面(2)的基础上在延伸一下: 可以将静态分配数据,建立表格,存放学生信息 2 加载到静态数据 3 html的编写直接在表格里添加一组数据就行了 4 V ...