迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > C++ >

在 C++ 中使用 STL 工具反转向量元素

作者:迹忆客 最近更新:2023/03/23 浏览次数:

本文将介绍如何在 C++ 中使用 STL 实用程序反转向量元素。

在 C++ 中使用 std::reverse 算法来反转向量元素

std::reverse 是 STL 算法的一部分,可用于反转任何给定范围内元素的顺序。std::reverse 算法在内部交换从第一对和最后一对开始的两个元素。std::reverse 接受两个参数,代表给定范围的迭代器。我们在下面的示例中生成随机整数作为 vector 对象,使用 std::reverse 算法将其反转并将结果输出到 cout 流。

#include <iostream>
#include <iterator>
#include <iomanip>
#include <random>
#include <vector>

using std::cout; using std::endl;
using std::setw; using std::left;

void generateNumbers(std::vector<int> &arr, size_t &width){

    std::srand(std::time(nullptr));
    for (size_t i = 0; i < width; i++) {
        arr.push_back(std::rand() % 100);
    }
}

int main() {
    size_t width = 10;
    std::vector<int> arr;
    arr.reserve(width);

    generateNumbers(arr, width);

    cout << left << setw(10) << "arr: ";
    copy(arr.begin(), arr.end(),
         std::ostream_iterator<int>(cout,"; "));
    cout << endl;

    std::reverse(arr.begin(), arr.end());

    cout << left << setw(10) << "arr: ";
    copy(arr.begin(), arr.end(),
         std::ostream_iterator<int>(cout,"; "));
    cout << endl;


    return EXIT_SUCCESS;
}

输出:

arr:      78; 56; 63; 59; 16; 7; 54; 98; 87; 92;
arr:      92; 87; 98; 54; 7; 16; 59; 63; 56; 78;

使用 std::shuffle 算法在 C++ 中随机重新排序向量元素

std::shuffle 可用于对范围内的元素进行随机重新排序,以便元素的每个排列具有相等的概率。该函数至少有两个参数,表示范围的开始和结束迭代器。可选地,std::shuffle 可以采用表示随机数生成器函数的第三个参数。在这种情况下,我们使用了 mersenne_twister_engine,它在 <random> 标头下提供。

#include <iostream>
#include <iterator>
#include <iomanip>
#include <random>
#include <vector>

using std::cout; using std::endl;
using std::setw; using std::left;

void generateNumbers(std::vector<int> &arr, size_t &width){

    std::srand(std::time(nullptr));
    for (size_t i = 0; i < width; i++) {
        arr.push_back(std::rand() % 100);
    }
}

int main() {
    size_t width = 10;
    std::vector<int> arr;
    arr.reserve(width);

    generateNumbers(arr, width);

    cout << left << setw(10) << "arr: ";
    copy(arr.begin(), arr.end(),
         std::ostream_iterator<int>(cout,"; "));
    cout << endl;

    std::shuffle(arr.begin(), arr.end(), std::mt19937(std::random_device()()));

    cout << left << setw(10) << "arr: ";
    copy(arr.begin(), arr.end(),
         std::ostream_iterator<int>(cout,"; "));
    cout << endl;


    return EXIT_SUCCESS;
}

输出:

arr:      40; 77; 74; 41; 79; 21; 81; 98; 13; 90;
arr:      79; 41; 90; 77; 21; 81; 98; 74; 13; 40;

在 C++ 中使用 std::rotate 算法旋转向量元素

STL 算法中包含的另一个有用函数是 - std::rotate。该函数将元素向左移动并环绕移动到向量边界之外的元素。std::rotate 接受 ForwardIt 迭代器类型的三个参数并执行旋转,以便将第二个参数指向的元素移动到新生成列表的第一个位置。

#include <iostream>
#include <iterator>
#include <iomanip>
#include <random>
#include <vector>

using std::cout; using std::endl;
using std::setw; using std::left;

void generateNumbers(std::vector<int> &arr, size_t &width){

    std::srand(std::time(nullptr));
    for (size_t i = 0; i < width; i++) {
        arr.push_back(std::rand() % 100);
    }
}

int main() {
    size_t width = 10;
    std::vector<int> arr;
    arr.reserve(width);

    generateNumbers(arr, width);

    cout << left << setw(10) << "arr: ";
    copy(arr.begin(), arr.end(),
         std::ostream_iterator<int>(cout,"; "));
    cout << endl;

    std::rotate(arr.begin(), arr.begin()+(width/2), arr.begin() + width);

    cout << left << setw(10) << "arr: ";
    copy(arr.begin(), arr.end(),
         std::ostream_iterator<int>(cout,"; "));
    cout << endl;


    return EXIT_SUCCESS;
}

输出:

arr:      75; 16; 79; 62; 53; 5; 77; 50; 31; 54;
arr:      5; 77; 50; 31; 54; 75; 16; 79; 62; 53;

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 C++ 中通过掷骰子生成随机值

发布时间:2023/04/09 浏览次数:169 分类:C++

本文解释了如何使用时间因子方法和模拟 C++ 中的掷骰子的任意数方法生成随机数。了解它是如何工作的以及它包含哪些缺点。提供了一个 C++ 程序来演示伪数生成器。

在 C++ 中使用模板的链表

发布时间:2023/04/09 浏览次数:158 分类:C++

本文解释了使用模板在 C++ 中创建链表所涉及的各个步骤。工作程序演示了一个链表,该链表使用模板来避免在创建新变量时声明数据类型的需要。

在 C++ 中添加定时延迟

发布时间:2023/04/09 浏览次数:142 分类:C++

本教程将为你提供有关在 C++ 程序中添加定时延迟的简要指南。这可以使用 C++ 库为我们提供的一些函数以多种方式完成。

在 C++ 中创建查找表

发布时间:2023/04/09 浏览次数:155 分类:C++

本文重点介绍如何创建查找表及其在不同场景中的用途。提供了三个代码示例以使理解更容易,并附有代码片段以详细了解代码。

如何在 C++ 中把字符串转换为小写

发布时间:2023/04/09 浏览次数:63 分类:C++

介绍了如何将 C++ std::string 转换为小写的方法。当我们在考虑 C++ 中的字符串转换方法时,首先要问自己的是我的输入字符串有什么样的编码

如何在 C++ 中确定一个字符串是否是数字

发布时间:2023/04/09 浏览次数:163 分类:C++

本文介绍了如何检查给定的 C++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便