RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1256275
Accepted
Максим Филимонов
Максим Филимонов
Asked:2022-03-15 23:28:10 +0000 UTC2022-03-15 23:28:10 +0000 UTC 2022-03-15 23:28:10 +0000 UTC

重新排列数组中的数字

  • 772
#include <iostream>

using namespace std;

int main() {
    int n;
    cin >> n;
    long long arr1[n];
    for (int i = 0; i < n; i++) {
        cin >> arr1[i];
    }
    for (int i = 0; i < n; i++) {
        for (int k = i; k < n; k++) {
            if (arr1[k] % 2 == 0) {
                long long t = arr1[k];
                arr1[k] = arr1[i];
                arr1[i] = t;
            }
        }
        cout << arr1[i] << " ";
    }
}

有必要重新排列数组中的偶数和奇数,使偶数在开头,奇数仅在它们之后。必须保持顺序

数字已重新排列,但顺序未保留,请帮助

c++
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Best Answer
    Harry
    2022-03-15T23:34:13Z2022-03-15T23:34:13Z

    它是 C++,所以在一行中 -

    stable_sort(arr1,arr1+n,[](auto a, auto b) { return abs(a)%2 < abs(b)%2; });
    

    如果我理解正确,您的“必须保留序列”...

    • 3
  2. avp
    2022-03-16T02:29:53Z2022-03-16T02:29:53Z
    #include <iostream>
    
    #include <stdio.h>
    #include <stdlib.h>
    
    
    using namespace std;
    
    void print_arr (long long a[], size_t n)
    {
      for (size_t i = 0, j = 0; i < n; i++)
        cout << a[i] << ' ';
      cout << '\n';
    }
    
    int main() {
      int n;
      cin >> n;
      long long arr1[n];
      for (int i = 0; i < n; i++) {
        arr1[i] = random() % 100;
        if (random() % 100 > 49)
          arr1[i] = -arr1[i];
      }
    
      print_arr(arr1, n);
    
      long long *t = (__typeof__(t))malloc(n * sizeof(t[0]));
      size_t j = 0, k = 0;
      for (size_t i = 0; i < n; i++) 
        if (arr1[i] & 1LL) // odd number
          t[k++] = arr1[i];
        else
          arr1[j++] = arr1[i];
    
      print_arr(arr1, j);
      print_arr(t, k);
    
      for (size_t i  = 0; j < n; j++)
        arr1[j] = t[i++];
      free(t);
      
      print_arr(arr1, n);
    
      return puts("End") == EOF;
    }
    
    • 1
  3. Stanislav Volodarskiy
    2022-03-16T03:00:04Z2022-03-16T03:00:04Z

    如果有额外的内存,stable_partition 在线性时间内解决问题,如果没有,则在 NlogN 中解决。

    // g++ -std=c++11 -pedantic -Wall -Wextra -Werror stable-partition.cpp
    
    #include <algorithm>
    #include <iostream>
    #include <iterator>
    #include <vector>
    
    using namespace std;
    
    int main() {
        int n;
        cin >> n;
        std::vector<long long> a;
    
        std::copy_n(
            std::istream_iterator<long long>(std::cin),
            n,
            std::back_inserter(a)
        );
    
        std::stable_partition(
            a.begin(),
            a.end(),
            [](long long v) { return v % 2 == 0; }
        );
    
        std::copy(
            a.begin(),
            a.end(),
            std::ostream_iterator<long long>(std::cout, " ")
        );
        std::cout << '\n';
    }
    
    $ g++ -std=c++11 -pedantic -Wall -Wextra -Werror stable-partition.cpp
    $ echo 11 1 2 3 4 5 6 7 8 9 -1 -2 | ./a.out 
    2 4 6 8 -2 1 3 5 7 9 -1
    

    一些笔记

    标准 C++ 不包含可变长度数组。long long arr1[n];这是关于一个n不是常量的字符串。GCC 支持它们作为扩展,但vector在这里更合适。

    既然我们这里有这么一个C++,那么在没有循环的情况下读/写数组也更符合逻辑。

    • 1

相关问题

  • 编译器和模板处理

  • 指针。找到最小数量

  • C++,关于枚举类对象初始化的问题

  • 函数中的二维数组

  • 无法使用默认构造函数创建类对象

  • C++ 和循环依赖

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5