博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Sort Array By Parity
阅读量:7080 次
发布时间:2019-06-28

本文共 1629 字,大约阅读时间需要 5 分钟。

hot3.png

Sort Array By Parity

Given an array A of non-negative integers, return an array consisting of all the even elements of A, followed by all the odd elements of A.

You may return any answer array that satisfies this condition.

Example 1:

Input: [3,1,2,4]

Output: [2,4,3,1]

The outputs [4,2,3,1], [2,4,1,3], and [4,2,1,3] would also be accepted.

说明

这个题目的意思是,将一个数列中的顺序调整为:前半部分为偶数,后半部分为奇数。除此之外,数列不必有序。

我用了快速排序的思路,从头和尾两边对数列进行遍历。

从左边开始,遇到奇数就停止遍历;然后从右边开始进行遍历,遇到偶数就停止遍历。 最后将这两个数交换顺序。

两边的遍历指针相遇的时候,整个工作结束。

MySolution

class Solution2{public:    vector
sortArrayByBarity(vector
&A) { int head = 0; int rear = A.size()-1; while(head < rear) { while((A[head]%2==0) && (head < rear)) head++; while((A[rear]%2==1) && (head < rear)) rear--; if(head < rear) swap(A[head++],A[rear--]); } return A; }};

测试代码

#include
#include
#include
using namespace std;class Solution2{public: vector
sortArrayByBarity(vector
&A) { int head = 0; int rear = A.size()-1; while(head < rear) { while((A[head]%2==0) && (head < rear)) head++; while((A[rear]%2==1) && (head < rear)) rear--; if(head < rear) swap(A[head++],A[rear--]); } return A; }};int main(void){ vector
a; a.push_back(100); a.push_back(4); a.push_back(200); a.push_back(1); a.push_back(3); a.push_back(2); cout<

转载于:https://my.oschina.net/u/1771419/blog/2054462

你可能感兴趣的文章
AngularJS内置指令
查看>>
冒泡排序算法分析
查看>>
Go函数
查看>>
青少儿书画 正式版发布
查看>>
大型网站技术架构(一)大型网站架构演化
查看>>
CEPH集群RBD快照创建、恢复、删除、克隆
查看>>
大型网站技术架构(六)网站的伸缩性架构
查看>>
MyBatis学习总结(四)——解决字段名与实体类属性名不相同的冲突
查看>>
Linux发生问题怎么处理啊?建议流程是这样...[鸟哥的Linux私房菜]
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
大型网站技术架构(五)网站高可用架构
查看>>
SVN学习总结(2)——SVN冲突解决
查看>>
MySQL基本
查看>>
<org manual>翻译--3.2 列的宽度与对齐
查看>>
我的友情链接
查看>>
《未测试》如何使用自己已经编译过的lamp安装cacti nagios zabbix
查看>>
SCVMM 2012 R2之为云分配虚拟机
查看>>
中国企业的等级制度
查看>>
pfSense安装和配置pfBlockerNg
查看>>
Ubuntu 14.04 X64 下安装Appcelerator Titanium Studio。
查看>>