两种方法

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

http://www.nowcoder.com/questionTerminal/beb5aa231adc45b2a5dcc5b62c93f593

一、使用辅助数组

使用两个辅助数组,一个用来存偶数,一个用来存奇数,时间复杂度O(n),代码如下:

            if (array==null||array.length==0)
                return;
            //解法1:排序+额外空间
            LinkedList<Integer> oddList=new LinkedList<>();
            LinkedList<Integer> evenList=new LinkedList<>();
            for (int item:array){
                if ((item&1)==0)
                    evenList.add(item);
                else
                    oddList.add(item);
            }
            int p=0;
            for (int i:oddList)
                array[p++]=i;
            for (int i:evenList)
                array[p++]=i;

二、双指针

利用双指针,p1遇到偶数先停下来,p2向后移动,直到遇到奇数,将奇数换到前面,然后将p1和p2之间的数字整体后移。代码如下:

            if (array==null||array.length==0)
                return;
            int p1=0,p2=0;
            while (true){
                //找到第一个偶数,停下来
                for (;p1<array.length;++p1){
                    if ((array[p1]&1)==0)
                        break;
                }
                //找到第一个奇数,停下来
                for (p2=p1+1;p2<array.length;++p2){
                    if ((array[p2]&1)==1)
                        break;
                }
                if (p1==array.length||p2==array.length)
                    break;
                //将p1-p2之间的数据整体往后移
                int tmp=array[p2];
                for (int i=p2;i>p1;--i){
                    array[i]=array[i-1];
                }
                array[p1]=tmp;
            }
全部评论

相关推荐

12-08 16:04
门头沟学院 Java
本人本科末9,今年大三。大一大二一直玩,什么都没学到,在大学混日子混了两年,每天不是在打农就是在steam。大三开学时一个和自己玩的好的同学去实习了,才发现自己白白浪费了两年的时间,如果真不冲一下就真去京东,阿里,美团送外卖了今年9月份开始学Java,一开始一直跟着黑马视频看,后面发现看视频效率太低了,时间根本不够,就开始主要看文档和看书了。这几个月一直在学,真的尽力了,希望暑期前能找一份好点的实习。我简历上面的项目大多没有指标,但是实际上我是真没多少时间去做项目,我基本主要是动手只做了外卖和天机,黑马点评和12306我都是只是看了项目。主要是自己的时间真的不多,但是这样子自己的代码能力确实比较差。而且自己也没有做过实际的工程,我顶多用jmeter测试一下接口tps啥的,比如使用Redis管道提升了一点性能,减少Redis交互,这种值得写上去吗?需不需要具体到某些数字求求各位佬给一些建议,看看简历怎么优化?项目介绍是不是不够详细?没有具体到业务方面。项目会不会提到大致实现原理导致面试官一看简历就知道怎么实现就没有问的欲望?专业技能一些字段是不是要加粗,是不是写太啰嗦了?有没有必要压缩内容变成一页?两页的话是不是都要把两页填地满满的。
给秋招一个交代:一页简历最好,网上做的项目放面试官眼里都是玩具,简历上不需要强调有什么难点,记住就行防止真的问。然后背八股,多投多面试就行
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务