题目来源:剑指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. 【阿里云IoT+YF3300】13.阿里云IoT Studio WEB监控界面构建

    Web可视化开发是阿里云IoT Studio中比较重要的一个功能,通过可视化拖拽的方式,方便地将各种图表组件与设备相关的数据源关联,无需编程,即可将物联网平台上接入的设备数据可视化展现. 目前支持的组 ...

  2. 自己动手开发手机APP控制西门子200smart 教程(原创干货)

    自己动手开发手机APP控制西门子200smart 教程(原创干货)   自己动手开发手机APP控制西门子200smart 教程(原创干货) 2020-02-09 19:06:45 自己动手开发手机AP ...

  3. mysql笔记(暂时)

    2018-05-28 create table cms_user(id int key auto_increment,username varchar(20),password varchar(20) ...

  4. vb.net datagridview 使用方法

    目录:  1. 取得或者修改当前单元格的内容  2. 设定单元格只读  3. 不显示最下面的新行  4. 判断新增行  5. 行的用户删除操作的自定义  6. 行.列的隐藏和删除  7. 禁止列或者行 ...

  5. PAT基础编程练习

    7-1 厘米换算英尺英寸 (15 分)   如果已知英制长度的英尺foot和英寸inch的值,那么对应的米是(.现在,如果用户输入的是厘米数,那么对应英制长度的英尺和英寸是多少呢?别忘了1英尺等于12 ...

  6. 利用Kubernetes中的leaderelection实现组件高可用

    在Kubernetes中,通常kube-schduler和kube-controller-manager都是多副本进行部署的来保证高可用,而真正在工作的实例其实只有一个.这里就利用到 leaderel ...

  7. AppBox实战: 如何实现一对多表单的增删改查

      本篇通过完整示例介绍如何实现一对多关系表单的相应服务及视图. 一.准备数据结构   示例所采用的数据结构为"物资需求"一对多"物资清单",通过IDE的实体设 ...

  8. ASP.NET Core ResponseCache进行缓存操作

    前言 本章将介绍客户端缓存将介绍浏览器缓存和服务端缓存,使用浏览器缓存将减少对web服务器的请求次数,同时可以提升性能,避免重复的运算浪费. ASP.NET Core对于HTTP缓存分为两种: 客户端 ...

  9. 目标检测:yolo-v3与faster-rcnn

    一. 算法背景 1. 机器视觉实际应用往往涉及包含多个物体的复杂场景,基于深度卷积神经网络的特征提取器,需要结合其他算法来准确定位多个目标,并进行识别. 2. 工业领域,目标检测算法在安防和质检系统都 ...

  10. Zookeeper分布式系统协同器概念快速学习

    原文格式可以访问:https://www.rockysky.tech 分布式系统的基本操作 主节点选举:在绝大多数分布式系统中,都需要进行主节点选举.主节点负责管理协调其它节点或者同步集群中其它节点的 ...