[Jobdu] 题目1516:调整数组顺序使奇数位于偶数前面
- 题目描述:
 - 
输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。
 
- 输入:
 - 
每个输入文件包含一组测试案例。
对于每个测试案例,第一行输入一个n,代表该数组中数字的个数。
接下来的一行输入n个整数。代表数组中的n个数。 
- 输出:
 - 
对应每个测试案例,
输入一行n个数字,代表调整后的数组。注意,数字和数字之间用一个空格隔开,最后一个数字后面没有空格。 
- 样例输入:
 - 
5
1 2 3 4 5 
- 样例输出:
 - 
1 3 5 2 4
 
对于普通的交换顺序,只要设两个指针分别从头跟尾扫描,当分别遇到不符合条件的位置时停止,然后交换位置,这样只要时间O(n),空间O(1),但是这样做会改变原来的顺序,要保持原来的位置,可以借用一个队列,先将一类数放到正确的位置上,再将队列里的数放到剩下的位置。时间仍为O(n),但是要用额外空间,大小取决于输入。最坏情况下空间为O(n)。
#include <stack>
#include <cstdio>
#include <iostream>
#include <queue>
using namespace std; int main() {
//freopen("1516.input", "r", stdin);
vector<int> v;
queue<int> q;
int n;
while (scanf("%d", &n) != EOF) {
v.resize(n);
for (int i = ; i < n; ++i) {
scanf("%d", &v[i]);
}
int count = ;
for (int i = ; i < n; ++i) {
if (v[i] % == ) {
v[i - count] = v[i];
} else {
++count;
q.push(v[i]);
}
}
for (int i = n - count; i < n; ++i) {
v[i] = q.front();
q.pop();
}
for (int i = ; i < n; ++i) {
(i == n - ) ? printf("%d\n", v[i]) : printf("%d ", v[i]);
}
}
return ;
} /**************************************************************
Problem: 1516
User: hupo250
Language: C++
Result: Accepted
Time:90 ms
Memory:2048 kb
****************************************************************/
附上通过交换元素不保持相对顺序的代码。
#include <vector>
#include <cstdio>
#include <iostream>
using namespace std; int main() {
//freopen("1516.input", "r", stdin);
int n;
vector<int> v;
while (scanf("%d", &n) != EOF) {
v.resize(n);
for (int i = ; i < n; ++i) {
scanf("%d", &v[i]);
}
int s = , e = n - , t;
while (s < e) {
while (!v[s] & && s < e) ++s;
while (v[s] & && s < e) --e;
t = v[s];
v[s] = v[e];
v[e] = t;
}
for (int i = ; i < n; ++i) {
(i == n - ) ? printf("%d\n", v[i]) : printf("%d ", v[i]);
}
}
return ;
}
[Jobdu] 题目1516:调整数组顺序使奇数位于偶数前面的更多相关文章
- [Jobdu] 题目1516 : 调整数组顺序使奇数位于偶数前面
		
void diffOddAndEven(int a[], int n) { , high = n - ; int pivot; while (low < high) { == && ...
 - 剑指Offer - 九度1516 - 调整数组顺序使奇数位于偶数前面
		
剑指Offer - 九度1516 - 调整数组顺序使奇数位于偶数前面2013-11-30 02:17 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部 ...
 - 九度OJ 1516 调整数组顺序使奇数位于偶数前面 -- 归并排序
		
题目地址:http://ac.jobdu.com/problem.php?pid=1516 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的 ...
 - 剑指Offer面试题:13.调整数组顺序使奇数位于偶数前面
		
一.题目:调整数组顺序使奇数位于偶数前面 题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 例如有以下一个整数数组:12345 ...
 - 剑指Offer面试题:11.调整数组顺序使奇数位于偶数前面
		
一 题目:调整数组顺序使奇数位于偶数前面 题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 二 解题思路 如果不考虑时间复杂度 ...
 - 九度oj 题目1516:调整数组顺序使奇数位于偶数前面
		
题目1516:调整数组顺序使奇数位于偶数前面 时间限制:1 秒 内存限制:128 兆 特殊判题:否 提交:3416 解决:1091 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序, ...
 - 【剑指Offer面试题】 九度OJ1516:调整数组顺序使奇数位于偶数前面
		
题目链接地址: http://ac.jobdu.com/problem.php?pid=1516 题目1516:调整数组顺序使奇数位于偶数前面 时间限制:1 秒内存限制:128 兆特殊判题:否提交:2 ...
 - 剑指offer:调整数组顺序使奇数位于偶数前面
		
题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分. 分析 事实上,这个题比较简单,很多种方式都可以实现,但是其时间复杂度或空间复 ...
 - C++版 - 剑指offer面试题14: 调整数组顺序使奇数位于偶数前面
		
题目: 调整数组顺序使奇数位于偶数前面 热度指数:11843 时间限制:1秒 空间限制:32768K 本题知识点: 数组 题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇 ...
 - 【Java】 剑指offer(21) 调整数组顺序使奇数位于偶数前面
		
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇 ...
 
随机推荐
- MySQL数据源在Spring中的配置
			
干脆把MySQL的数据源配置也一起放这里,以备不时之需. MySQL的驱动包可以从这里 http://pan.baidu.com/s/1d02aZ 下载. 以下粗体部分是需要你根据实际情况调整的. & ...
 - C#.NET常见问题(FAQ)-如何将cs文件编译成dll文件 exe文件 如何调用dll文件
			
比如我要把TestDLL.cs文件编译成dll文件,则在命令提示符下,输入下面的命令,生成的文件为TestDLL.dll csc /target:library TestDLL.cs 注意前提是你安装 ...
 - UE自动将关键字首字母大写怎么办
			
对于某些关键字,UE会自动将首字母大写. 只要选中这些文字,右键选择"格式",转为小写字母即可.
 - C++ vector类型要点总结
			
概述 C++内置的数组支持容器的机制,但是它不支持容器抽象的语义.要解决此问题我们自己实现这样的类.在标准C++中,用容器向量(vector)实现. 容器向量也是一个类模板.vector是C++标准模 ...
 - Windows平台Hadoop编译、安装、配置与运行(转)
			
http://www.srccodes.com/p/article/38/build-install-configure-run-apache-hadoop-2.2.0-microsoft-windo ...
 - VB总结1-事件过程之键盘鼠标过程
			
事件过程:参考 (http://baike.baidu.com/view/1523990.htm) 事件是指对象对于外部动作的响应,当对象发生了某个事件,就会执行与此对象的这个事件相应的代码,这段代码 ...
 - word2vec模型cbow与skip-gram的比较
			
cbow和skip-gram都是在word2vec中用于将文本进行向量表示的实现方法,具体的算法实现细节可以去看word2vec的原理介绍文章.我们这里大体讲下两者的区别,尤其注意在使用当中的不同特点 ...
 - 关于linux的添加永久静态路由的static-routes方法
			
一:使用 route 命令添加 使用route 命令添加的路由,机器重启或者网卡重启后路由就失效了,方法: //添加到主机的路由 # route add –host 192.168.1.11 dev ...
 - [Python]网络爬虫(五):urllib2的使用细节与抓站技巧
			
转自:http://blog.csdn.net/pleasecallmewhy/article/details/8925978 前面说到了urllib2的简单入门,下面整理了一部分urllib2的使用 ...
 - onkeydown-onkeypress-onkeyup
			
CreateTime--2016年12月17日22:28:36Author:Marydononkeydown.onkeypress和onkeyup参考链接:http://www.jb51.net/ ...