剑指offer-第三章高质量的代码(调整数组顺序使得奇数位于偶数的前面)
题目:输入一个整数数组,实现一个函数中调整该数组中数字的顺序,使得所有的奇数位于数组的前半部,所有偶数位于数组的后半部。
思路:用两个指针p1和p2,分别指向数组的头和尾部,p1只向后移,p2只向前移。当满足p1<p2这个条件时,可以将p1向后移并找到第一偶数为止,p2向前移直到找到第一个奇数为止,此时如果还满足p1<p2的条件,则交换p1和p2的值。
c++代码:本代码扩展性的体现为:将函数bool (*func) (int)当做参数传人preorder中,而此时要判断数字的奇偶性,可以写一个如上格式所示的函数:bool isEven(int n).
当题目改变,要求将数组中能整除3的数放在前面,其他的数组放在后面的时候,就可以写一个如上格式所示的其他函数。
#include<iostream>
using namespace std;
void preorder(int* pdata,unsigned int length,bool (*func) (int))
{
if(pdata==NULL||length==)
return;
int* pstart=pdata;
int* pend=pdata+length-;
while(pstart<pend)
{
while(pstart<pend&&!func(*pstart))
pstart++;
while(pstart<pend&&func(*pend))
pend--;
if(pstart<pend)
{
int temp=*pstart;
*pstart=*pend;
*pend=temp;
}
} }
bool isEven(int n)
{
return (n&)==;
}
void preorderOddEven(int* pdata,unsigned int length)
{
preorder(pdata,length,isEven);
}
void main()
{
int a[]={,,,,};
int* pdata=a;
preorderOddEven(pdata,);
for(int i=;i<;i++)
cout<<pdata[i]<<" ";
cout<<endl; }
Java代码:体现扩展性的方法是写一个接口,里面放一个抽象方法boolean func(int n),其他具体的题目,都只要实现这个方法即可。
public class PreorderOddEven {
    /*
     * 将一个数组中的奇数排在偶数的前面
     * @param pdata 数组
     * @param length 数组的长度
     */
    public void preorder(int[] pdata,int length)
    {
        if(pdata==null||length<=0)
            return;
        int pstart=0;
        int pend=length-1;
        while(pstart<pend)
        {
            while(pstart<pend&&!isEven(pdata[pstart]))
                pstart++;
            while(pstart<pend&&isEven(pdata[pend]))
                pend--;
            if(pstart<pend)
            {
                int temp=pdata[pstart];
                pdata[pstart]=pdata[pend];
                pdata[pend]=temp;
            }
        }
    }
    /*
     * 判断数组中数字的奇偶性
     * @param n 数组中的数字
     */
    public  boolean isEven(int n) {
        return (n&1)==0;
    }
    public static void main(String[] args)
    {
        PreorderOddEven poe=new PreorderOddEven();
        int[] a={1,2,3,4,5};
        poe.preorder(a,a.length);
        for(int i=0;i<5;i++)
            System.out.print(a[i]+" ");
    }
}
剑指offer-第三章高质量的代码(调整数组顺序使得奇数位于偶数的前面)的更多相关文章
- 【剑指Offer面试题】 九度OJ1516:调整数组顺序使奇数位于偶数前面
		
题目链接地址: http://ac.jobdu.com/problem.php?pid=1516 题目1516:调整数组顺序使奇数位于偶数前面 时间限制:1 秒内存限制:128 兆特殊判题:否提交:2 ...
 - 剑指offer编程题Java实现——面试题14调整数组顺序使奇数位于偶数之前
		
题目: 输入一个整数数组,实现一个函数来调整该数组中数组的顺序,使得所有的奇数位于数组的前半部分,偶数位于数组的后半部分. 解题思路:数组中维护两个指针,第一个指针初始化时候指向数组头部,第二个指针初 ...
 - 【剑指Offer面试编程题】题目1516:调整数组顺序使奇数位于偶数前面--九度OJ
		
题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变. 输入: 每个输 ...
 - 剑指offer—第三章高质量的代码(按顺序打印从1到n位十进制数)
		
题目:输入一个数字n,按照顺序打印出1到最大n位十进制数,比如输入3,则打印出1,2,3直到最大的3位数999为止. 本题陷阱:没有考虑到大数的问题. 本题解题思路:将要打印的数字,看成字符串,不足位 ...
 - 【剑指Offer学习】【面试题14 :调整数组顺序使奇数位于偶数前面】
		
题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序.使得全部奇数位于数组的前半部分.全部偶数位予数组的后半部分. 这个题目要求把奇数放在数组的前半部分, 偶数放在数组的后半部分,因此全部的奇 ...
 - 剑指offer—第三章高质量代码(数值的整数次方)
		
高质量的代码:容错处理能力,规范性,完整性.尽量展示代码的可扩展型和可维护性. 容错处理能力:特别的输入和处理,异常,资源回收. 规范性:清晰的书写,清晰的布局,合理的命名. 完整性:功能测试,边界测 ...
 - 剑指offer—第三章高质量代码(o(1)时间删除链表节点)
		
题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点,链表节点与函数的定义如下:struct ListNode{int m_nValue;ListNode* m_pValue ...
 - 剑指offer—第三章高质量代码(合并两个排序链表)
		
题目:输入员两个递增排序的链表,合并这两个链表并使新的链表中的结点仍然是按照递增排序的. 思路:首先,定义两个头节点分别为Head1和Head2的链表,然后比较第一个节点的值,如果是Head1-> ...
 - 剑指offer:调整数组顺序使奇数位于偶数前面
		
题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 分析 事实上,这个题比较简单,很多种方式都可以实现,但是其时间复杂度或空间复 ...
 - 【Java】 剑指offer(21) 调整数组顺序使奇数位于偶数前面
		
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇 ...
 
随机推荐
- 自制   JS.format带分页索引
			
//第一参数是:Json对象,第二个是 序号 第三个 页数 第四 当前页数String.prototype.format = function (args, sid, pagesi ...
 - jmeter if 控制器
			
判断变量值是不是为空(有没有被赋值): "${jd_aid}"!="\${jd_aid}"
 - eq相等 ,ne、neq不相等 EL表达式
			
eq相等,ne.neq不相等, gt大于, lt小于 gte.ge大于等于 lte.le 小于等于 not非 mod求模 is [not] div by是否能被某数整除 is [n ...
 - 李洪强iOS开发之OC语言基础知识
			
OC语言基础知识 一.面向对象 OC语言是面向对象的,c语言是面向过程的,面向对象和面向过程只是解决问题的两种思考方式,面向过程关注的是解决问题涉及的步骤,面向对象关注的是设计能够实现解决问题所需功能 ...
 - Android是什么 之三手机之硬件形态
			
手机硬件形态 本节可能与Android无关,但是Android系统现在这个阶段更多的是移动终端形态的开发平台,本节给出了Android背后的工作-Android管理的硬件是什么,Android的本质就 ...
 - 用Java编写你自己的简单HTTP服务器
			
http://blog.csdn.net/yanghua_kobe/article/details/7296156 原文不错. 服务器支持的并发连接数,就是要开多少个线程,每个线程里一个socket监 ...
 - Java-斐波那契数
			
1.目标:使用非递归求斐波那契,0, 1, 1, 2, 3, 5, 8, 13, 21, 34, ... 2.思路:观察规律得:从第3个数起,把和从为下一个数的加数,把加数作为下一个数的被加数,即三个 ...
 - 【重走Android之路】【路线篇(一)】路线图
			
总结归纳了J2SE和Android的知识点,自己制订了一套详细的路线图,其中肯定有考虑不全和不合适的地方,欢迎各位大牛批评指正. 详细路线图如下:
 - Linux系统VIM编辑器
			
vim,linux系统中一款超好用的文本编辑器,是vi的升级版. 三种操作模式 命令模式: 控制光标移动,可对文本进行删除.恢复.黏贴等工作 输入模式: 正常的文本录入 末行模式: 保存,退出与设置编 ...
 - Android 如何处理崩溃的异常
			
Android中处理崩溃异常 大家都知道,现在安装Android系统的手机版本和设备千差万别,在模拟器上运行良好的程序安装到某款手机上说不定就出现崩溃的现象,开发者个人不可能购买所有设备逐个调试 ...