将一个数组中的偶数放前面奇数放后面

问题

一个数组由若干个整数组成,现要求:将偶数放到前面,奇数放到后面,并输出数组。

解决(python)

#coding:utf-8
is_odd_number = lambda data:(data%2!=0)

def odd_even_sort(lst):
    """利用list conprehension"""
    tmp_list1 = [item for item in lst if is_odd_number(item)]
    tmp_list2 = [item for item in lst if not is_odd_number(item)]

test_lst = [7,9,12,5,4,9,8,3,12,89]

print (odd_even_sort(test_lst))

本问题由黄老师提供并解决,他的微博

解决(python)

def odd(x):return x%2==1    #判断是否为奇数,是则返回true
def even(x):return x%2==0   

if __name__=="__main__":
    test_lst = [7,9,12,5,4,9,8,3,12,89]
    print filter(even,test_lst)+filter(odd,test_lst)    #利用filter函数

解决 (racket 5.2.1)

#lang racket

; 定义函数 odd-even-separator
; 输入一个由整数构成的列表
; 输出一个新的列表, 其元素取自输入的列表
; 假设输入列表长度为 N, 列表元素中有 k 个偶数, N-k 个奇数
; 那么输出的列表中, 前 k 个元素就是输入列表中的 k 个偶数
; 后 N-k 个元素就是输入列表中的 N-k 个奇数.
(define (odd-even-separator num-array)
  (let*
      ([odd-arr (filter odd? arr1)]   ; 取出全部奇数形成新列表
       [even-arr (filter even? arr1)] ; 取出全部偶数形成新列表
       [separated-arr
        (append even-arr odd-arr)])   ; 把两个新列表连接起来
    (displayln separated-arr)))       ; 打印到标准输出

; 函数调用, 正常运行后, 应该显示 (2 6 4 1 3 5 7 9)
(odd-even-separator '(1 3 2 6 5 7 9 4))

更多算法问题,请到:https://github.com/qiwsir/algorithm/

将一个数组中的偶数放前面奇数放后面

时间: 2024-10-18 08:21:22

将一个数组中的偶数放前面奇数放后面的相关文章

如何将一个数组中的元素插入另一个数组

如何将一个数组中的元素插入另一个数组:本章节直接给出一段将一个数组中元素插入另一个数组中的代码实例,直接套用就可以了.代码如下: var first = ['a','b','c']; var second = ['1','2','3']; var index = 1; second.unshift(index, 0); Array.prototype.splice.apply(first, second); 原文地址是:http://www.softwhy.com/forum.php?mod=v

调整该数组中数字的顺序,奇数在前,偶数在后

题目描述 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变. class Solution { public: void reOrderArray(vector<int> &array) { vector<int> a,b; for(int i=0;i<array.size();i++) { if(array[i]%2==1) a.push_bac

算法题:将一个数组中所有奇数放前面和偶数放后面(不开辟新的内存空间)

package arithmetic; import java.util.Arrays; public class OddAndEven { public static void main(String[] args) { int [] a={5,10,26,32,41,7,9,8,4,12,1};; int low = 0; int high = a.length-1; /**想法: * 1.遍历.将奇数放在左边,偶数放在右边 * 2.先遍历左边,直到出现不是奇数的时候为止 * 3.再遍历右边

将一个数组中奇数放在数组前边,偶数放在数组后边

#include<stdio.h>int main(){ void odd_even_number(int *str, int size); int arr[10] = { 0 }; int len = sizeof(arr) / sizeof(arr[0]); int i = 0; for (i = 0; i < len; i++) {  scanf("%d", &arr[i]); } odd_even_number(arr, len); for (i =

[LeetCode283]Move Zeros将一个数组中为0的元素移至数组末尾

题目: Given an array nums, write a function to move all 0's to the end of it while maintaining the relative order of the non-zero elements. For example, given nums = [0, 1, 0, 3, 12], after calling your function, nums should be [1, 3, 12, 0, 0]. Note:

java 将一个数组中的值按逆序重新存放,例如,原来顺序为:9,5,7,4,8,要求改为:8,4,7, 5,9。

1 public class Test3 { 2 3 public static void main(String[] args) { 4 5 int[] grade = {87,88,89,98,78}; 6 7 int m; 8 for(int i = 0; i < 2; i++){ 9 10 m = grade[i]; 11 grade[i] = grade[5-i-1]; 12 grade[5-i-1] = m; 13 14 } 15 for(int j =0; j < 5; j++)

标把1-10之间所有的奇数,放到数组中

1 <script type="text/javascript"> 2 //三种方法 3 var arr=[]; 4 for(var i=1;i<=10;i++){ 5 if(i%2!=0){ 6 arr.push(i); 7 } 8 } 9 console.log(arr); 10 //2 11 var arr=[]; 12 for(var i=1;i<=10;i++){ 13 if(i%2!=0){ 14 arr[arr.length]=i; 15 } 16

数组中只出现一次的数字(java实现)

问题描述 一个整型数组里除了两个数字之外,其他的数字都出现了偶数次.请写程序找出这两个只出现一次的数字. 解题思路 如果数组中只有一个数字出现奇数次,则将数组中所有的数字做异或可得该数字. 数组中有两个数字出现奇数次,设这两个数字分别为a.b,则将数组中所有的数字做异或得到的是a与 b异或的结果,设为xor. 数字a与b不同,则a与b的二进制表示中至少存在1位不同,xor二进制表示中为1的位即是a与b不同的位,假设a与b的第k位不同,a在该位上为1,b在该位上为0 .(k可以选取为从起始位开始的

数组中,奇数放前偶数放后

题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变. 错误代码: public class Solution { public void reOrderArray(int [] array) { int len=array.length; for(int i=0;i<len;i++){ if((array[i]&1)==0){ int j; for(j=i;j<