前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >剑指offer代码解析——面试题14调整数组顺序使奇数在偶数之前

剑指offer代码解析——面试题14调整数组顺序使奇数在偶数之前

作者头像
大闲人柴毛毛
发布2018-03-09 15:36:19
6820
发布2018-03-09 15:36:19
举报
文章被收录于专栏:大闲人柴毛毛大闲人柴毛毛

本题详细解析都已在代码中注释了:

代码语言:javascript
复制
/**
 * 题目:输入一个数组,要求将奇数放在数组的前半段,偶数放在数组的后半段 
 * @author 大闲人柴毛毛
 */
public class Reorder {
	/**
	 * 分析:本题只要求前半段为奇数,后半段为偶数,没有要求有序,
	 * 因此可以采用快速排序中一趟排序的思想:
	 * 使用两个指针i、j,i指向头、j指向尾,分别向后、向前扫描;
	 * 若i遇到偶数则停下,j遇到奇数则停下,交换这两个数,
	 * 然后继续重复上述操作,直到i、j相遇为止。代码如下:
	 * PS:快速排序算法请看我的博客《剑指 offer——快速排序》
	 */
	public static boolean reorder(int[] a){
		//若数组为空
		if(a==null || a.length==0){
			System.out.println("数组为空!");
			return false;
		}
		
		//若数组只有一个元素,那不做任何操作
		if(a.length==1){
			System.out.println("数组长度为1,无需排序!");
			return true;
		}
		
		//若数组长度超过2,则进行排序
		int i=0,j=a.length-1;
		while(i<j){
			//i从头向后扫描,若当前元素为奇数,则继续往后扫描,若为偶数,i停止扫描。
			while(a[i]%2==1)
				i++;
			//j从后向前扫描,若当前元素为偶数,则继续往前扫描,若为奇数,j停止扫描。
			while(a[j]%2==0)
				j--;
			//当i、j都停止时,如果i和j还没有相遇,就交换这两个数
			if(i<j){
				int temp = a[i];
				a[i] = a[j];
				a[j] = temp;
			}
		}
		return true;
	}
	
	
	/**
	 * 上述代码运行过后会出现死循环!
	 * 当数组全为奇数时,i无限向后寻找,因此出现死循环。
	 * 因此,在i向后、j向前的循环中应多加一个判断:若i搜索到末尾,则停止、若j搜索到开头,则停止。
	 * 修改后的代码如下:
	 */
	public static boolean reorder_modify(int[] a){
		//若数组为空
		if(a==null || a.length==0){
			System.out.println("数组为空!");
			return false;
		}
		
		//若数组只有一个元素,那不做任何操作
		if(a.length==1){
			System.out.println("数组长度为1,无需排序!");
			return true;
		}
		
		//若数组长度超过2,则进行排序
		int i=0,j=a.length-1;
		while(i<j){
			//i从头向后扫描,若当前元素为奇数,则继续往后扫描,若为偶数,i停止扫描。
			while(i<a.length-1 && a[i]%2==1)
				i++;
			//j从后向前扫描,若当前元素为偶数,则继续往前扫描,若为奇数,j停止扫描。
			while(j>0 && a[j]%2==0)
				j--;
			//当i、j都停止时,如果i和j还没有相遇,就交换这两个数
			if(i<j){
				int temp = a[i];
				a[i] = a[j];
				a[j] = temp;
			}
		}
		return true;
	}
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年03月13日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档