zoukankan      html  css  js  c++  java
  • 剑指offer13-调整数组顺序使奇数位于偶数前面

    题目描述

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

    思路:

    简单的一种做法:设置一个新的数组。

    然后对原数组从头开始遍历,若是奇数,就复制到新数组中,遍历完一遍后;再遍历第二遍,从头到尾依次将偶数复制到新数组中。最后将新数组的值复制到原数组中

    class Solution {
    public:
         void reOrderArray(vector<int> &array){
             vector<int> arr;
             int length = array.size();
             for(int i=0;i<length;i++)
             {
                 if(array[i]%2==1)
                     arr.push_back(array[i]);
             }
             for(int i=0;i<length;i++)
             {
                 if(array[i]%2==0)
                     arr.push_back(array[i]);
             }
             array = arr;
         }
       
    };
    
    /*
     void reOrderArray(vector<int> &array) {
            //找不出问题,先暂存
            int length = array.size();
            int place_odd; //奇数的位置
            int place_even;//偶数的位置
            int i=0;
            int next;
            while(i<length)
            {
                if(array[i]%2==0)
                {
                    place_even=i;//交换的偶数
                    next = place_even+1;
                    i++;
                    while(array[i]%2==0)
                        i++;
                    place_odd = i;//交换的奇数
                    int temp = array[place_odd];//先将奇数暂存
                    for(int j=place_odd;j>place_even;j--)
                    {
                        array[j] = array[j-1];
                    }
                    array[place_even] = temp;
                    i = next;
                }
                else
                {
                    i++;
                }
            }
            
        }
    */
  • 相关阅读:
    C语言I博客作业08
    作业7
    作业6
    作业5
    作业--4
    java基础学习--I/O流
    刷题记录--[CISCN2019 华北赛区 Day2 Web1]Hack World
    ADB测试Android真机
    sqli-labs通关笔记
    Tensorflow入门
  • 原文地址:https://www.cnblogs.com/loyolh/p/12347087.html
Copyright © 2011-2022 走看看