NO13、调整数组顺序使奇数位于偶数前面(还不错、值得再看一遍)

本文主要是介绍NO13、调整数组顺序使奇数位于偶数前面(还不错、值得再看一遍),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

13、调整数组顺序使奇数位于偶数前面 值得再看一遍

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

1、暴力解法,新开辟一个数组保存数据
void reOrderArray(vector<int>& array) {vector<int> temp(array.size(), 0);int low = 0;for (int i = 0; i < array.size(); ++i) {if ((array[i] & 1) == 1) { temp[low++] = array[i]; }}for (int i = 0; i < array.size(); ++i) {if ((array[i] & 1) == 0) { temp[low++] = array[i]; }}array.assign(temp.begin(), temp.end());
}
2、一种很巧妙的解法,空间复杂度o1的做法,时间复杂度是on^2
void reOrderArray(vector<int>& array) {for (int i = 0; i < array.size(); i++){//for (auto a : array) {//	cout << a << " ";//}cout << endl;for (int j = array.size() - 1; j > i; j--){if (array[j] % 2 == 1 && array[j-1] % 2 == 0) //前偶后奇就进行交换,这样一趟下来可以将第一个奇数放在首位,同时最后一个偶数放在末尾{swap(array[j], array[j - 1]);}}}
}
3、时间和空间都是on的做法,只保存偶数部分
    void reOrderArray(vector<int> &array) {vector<int> temp(array.size(), 0);int oddIndex = 0, evenIndex = 0;for (auto a : array) {if ((a & 1) == 1) array[oddIndex++] = a;elsetemp[evenIndex++] = a;}for (int i = 0; i < evenIndex; ++i)array[oddIndex + i] = temp[i];}
二刷:
1、笨方法另外开辟一个数组,先保存奇数,再保存偶数
    void reOrderArray(vector<int> &array) {int len = array.size();if(len <= 1) return;int index = 0;vector<int> temp(len,0);for(int i=0;i<len;++i){if(array[i] %2 == 1) temp[index++] = array[i];}for(int i=0;i<len;++i){if(array[i] %2 == 0) temp[index++] = array[i];}array.assign(temp.begin(), temp.end());}
2、一种原地解法,很巧妙,从后向前进行修正,类似于冒泡法,同时对一刷的时候进行改进

运行时间:2ms 占用内存:480k

    void reOrderArray(vector<int> &array) {int len = array.size();if (len <= 1) return;for (int i = 0; i <= len/2; ++i) {for (int j = len - 1; j > i; --j) {if ( (array[j]&1) == 1 && (array[j - 1]&1) == 0)  swap(array[j], array[j - 1]);//前偶后奇就进行交换,并且一次就可以固定最前面的奇数位置后最后面的偶数位置,所以最多只需要遍历一般数组的长度即可,所以i<=len/2即可}}}
3、第三种解法,但是并不是原地解法,至少比第一种要好一点,只保存偶数数据

运行时间:3ms 占用内存:484k odd奇数:even偶数

    void reOrderArray(vector<int> &array) {int len = array.size(),evenIndex = 0,oddIndex = 0;if (len <= 1) return;        vector<int> temp(len/2+1,0);for (int i = 0; i <len; ++i) {if ( (array[i]&1) == 1)  array[oddIndex++] = array[i];else{temp[evenIndex++] = array[i];//将偶数另外保存起来}}for(int j = 0;j < evenIndex; ++j){array[j + oddIndex] = temp[j];}}

美女帅哥们如果觉得写的还行,有点用的话麻烦点个赞或者留个言支持一下阿秀~
如果觉得狗屁不通,直接留言开喷就完事了。

需要该笔记PDF版本的去个人公众号【拓跋阿秀】下回复“阿秀剑指offer笔记”即可。

这篇关于NO13、调整数组顺序使奇数位于偶数前面(还不错、值得再看一遍)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/628159

相关文章

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

WiFi6时代来临! 华三H3C NX54路由器还值得购买吗?

《WiFi6时代来临!华三H3CNX54路由器还值得购买吗?》WiFi6时代已经来临,众多路由器厂商也纷纷推出了兼容WiFi6协议的路由器,今天我们将深入体验H3CNX54路由器,这款由知名企业... 随着科技的发展,WiFi6逐渐走进了我们的日常生活之中,相比WiFi5来说,WiFi6拥有更高的带宽、更高

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

Python批量调整Word文档中的字体、段落间距及格式

《Python批量调整Word文档中的字体、段落间距及格式》这篇文章主要为大家详细介绍了如何使用Python的docx库来批量处理Word文档,包括设置首行缩进、字体、字号、行间距、段落对齐方式等,需... 目录关键代码一级标题设置  正文设置完整代码运行结果最近关于批处理格式的问题我查了很多资料,但是都没

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::