题目来源:剑指offer

题目:

输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。

解题思路:

数组类题目指导原则:除了极其傻瓜式的题目,大部分数组类的题目都要用到 “双索引“策略,只不过有的采用对撞指针,有的采用跟随指针。

我们随便举出一个数组的例子,才分析怎么做才比较合适:2 4 7 4 3 5 8  10 9;

那么此时,你会怎么做,当然了,我们当然是需要找出所有的奇数,以及所有的偶数。基于这种找的思想,我们当然可以这么做:从头到尾判定这个数组的每个元素的奇偶性,然后生成一个和该数组同样大小的数组空间,将扫描到的奇数按原顺序放在新数组的前半部分,再将是扫描到的偶数放到新数组的后半部分,毫无疑问,这种策略但从结果上看,是没有任何问题的,问题在于:我们使用了一个和原数组同样大小的数组空间。这使得时间复杂度和空间复杂度都为O(n)可见,这样并不是一个好方法。有没有更好的方法呢?

当然有:

请别忘记我们最终要做的是:将奇数按照原来的顺序放到前面,偶数按照原来的顺序放到后面。有没有可能,我们仅仅在原空间上,做数据搬移就能实现这个愿望呢?答案是有的。

那么我们要发出的一个很自然的问题是:什么时候我们进行这种搬移?

当然是某一个奇数和它前面(左边)离他最远偶数之间,存在这种搬移。那么此时,很明显的需要两个索引来标识两个奇数和偶数。比如 上述序列:2 4 7 ,我们当然知道,正确的顺序是 7 2 4。那么我们应该怎么做呢?

代码:

我给出下面的核心代码,你大概就可以看懂了:

             tmp = array[j];//将奇数缓存起来
for(int k = j;k>i;k--)
array[k] = array[k-];
array[i] = tmp;//将奇数放到它应该在的位置

很明显,我们的做法是:将 7 缓存到一个变量中去,然后,将所有的偶数向后搬移一个单位,再将7放到它应该在的位置。上述代码就是解决这个问题的核心思路。

但我在调试的过程中仍然遇到了数组越界这样的问题:

我先把我的完整代码放在下面,以供参考:

 class Solution {
public:
void reOrderArray(vector<int> &array) {//tow pointer
int length = array.size();
int i = ;//奇数索引位置
int j = ;
int tmp;
if(length > )
{
while((i < length) &&(j < length))
{
while((i< length) && (array[i]% == ))
{//找到第一个偶数
i++;
}
j = i+;
while((j< length) && (array[j]% == ))
{//找到第一个奇数
j++;
}
if((j == length) || (i == length))
break;
tmp = array[j];//将奇数缓存起来
for(int k = j;k>i;k--)
array[k] = array[k-];
array[i] = tmp;//将奇数放到它应该在的位置
}
}
}
};

上述代码中,i和j就表示了双索引。在上述代码中,我多次将 i和j索引值与数组长度length作比较,目的就是为了防止越界。

比如:开头的if(length > 1),则是为了说明这个数组至少有两个元素。下述的找到第一个奇数和第一个偶数,我们也加上 i < length和 j < length的限制。目的是为了避免越界,比如:加入数组为全奇数和或者全偶数的情况,必然会导致越界。

总结:

我在思考核心代码上画的时间并不是很多,但是在防止数组越界的问题折腾了很久,最终才提交上去,我想表明的观点是:

  • 凡是数组问题必然要考虑越界问题,及时进行边界约束。
  • 凡是数组问题,我们一定要考虑数组为空,数组中有一个元素,数组中有n个元素的情况
  • 凡是数组问题,双索引几乎成了一个必选的 解决思路。

请记好上述三个凡是!!!

牛客网剑指offer第13题——调整数组顺序使得奇数位于偶数前面的更多相关文章

  1. 剑指offer(13)调整数组顺序使奇数位于偶数前面

    题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变. 题目分析 判断是 ...

  2. 【剑指Offer】13、调整数组顺序使奇数位于偶数前面

      题目描述:   输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变.   解题思 ...

  3. 剑指Offer - 九度1516 - 调整数组顺序使奇数位于偶数前面

    剑指Offer - 九度1516 - 调整数组顺序使奇数位于偶数前面2013-11-30 02:17 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部 ...

  4. 剑指Offer:面试题14——调整数组顺序使奇数位于偶数前面(java实现)

    问题描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 思路: 1.最简单的想法,不考虑时间复杂度,扫描数组,遇到偶数,先取出这 ...

  5. C++版 - 剑指offer面试题14: 调整数组顺序使奇数位于偶数前面

    题目: 调整数组顺序使奇数位于偶数前面 热度指数:11843 时间限制:1秒 空间限制:32768K 本题知识点: 数组 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇 ...

  6. 【剑指offer】Q14:调整数组顺序使奇数位于偶数前面

    def isOdd(n): return n & 1 def Reorder(data, cf = isOdd): odd = 0 even = len( data ) - 1 while T ...

  7. 【Offer】[21] 【调整数组顺序使奇数位于偶数前面】

    题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,(偶数之间和奇数 ...

  8. 牛客网剑指offer第19题——顺时针打印矩阵

    这个题看似很简单: 题目: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 1 ...

  9. 牛客网剑指offer第21题——判断出栈序列是否是入栈序列

    题目: 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈 ...

随机推荐

  1. BP的matlab实现

    %2015.04.26 Kang Yongxin ----v 2.0 %完成作业中BP算法,采用批量方式更新权重 %% %输入数据格式 %x 矩阵 : 样本个数*特征维度 %y 矩阵 :样本个数*类别 ...

  2. Nutz框架-- Cnd条件使用原生sql

    案例 今天接到一个临时的业务需求,做一个简单的过滤作为临时业务需要使用一两天,于是想到在原有的Cnd条件上加上一个Not like 进行过滤,但是发现现有Cnd条件查询好像满足不了 解决方案 使用Nu ...

  3. OpenCV中Mat与二维数组之间的转换

    ---恢复内容开始--- 在OpenCV中将Mat(二维)与二维数组相对应,即将Mat中的每个像素值赋给一个二维数组. 全部代码如下: #include <iostream> #inclu ...

  4. 十五 awk文本处理

    Awk 语法和基础命令 以行为处理单位 对数据进行逐行处理 处理完当前行,把当前行的处理结果输出后自动对下一行进行处理 直到文件中所有行处理完为止 创造者:Aho.Weinberger.Kernigh ...

  5. solaris系统磁盘镜像

    查看磁盘分区 查看系统的磁盘数据与容量: 用format查看一下磁盘的情况,0号盘是c1t0d0,系统源磁盘,1号盘是c1t1d0,新增加磁盘,作为镜像盘使用. 注意:两块硬盘的容量最好相等,如果镜像 ...

  6. WeChall_PHP 0817 (PHP, Exploit)

    I have written another include system for my dynamic webpages, but it seems to be vulnerable to LFI. ...

  7. 牛客练习赛52 B Galahad (树状数组)

    题目链接:https://ac.nowcoder.com/acm/contest/1084/B 题意 5e5的区间,5e5个询求[l,r]区间内出现过的数的和 思路 1s时限,莫队显然会T 我们可以将 ...

  8. sqlserver install on linux chapter two

    The previous chapter is tell us how to install sqlerver on linuix Today, we will see how to make it ...

  9. mybaitis的延迟加载

    概念:延迟加载:用到的时候才加载 因为我们在多表查询是,效率不如单表快,多个单表查询,然后使用懒加载,完成 多表关联查询 什么情况下使用懒加载 mybaitis中的表关系是一对一或者一对多的时候 我们 ...

  10. 使用Python打造一款间谍程序

    知识点 这次我们使用python来打造一款间谍程序 程序中会用到许多知识点,大致分为四块 win32API  此处可以在MSDN上查看 Python基础重点在cpytes库的使用,使用方法请点击此处 ...