legongju.com
我们一直在努力
2025-01-20 19:21 | 星期一

如何利用C++ set集合解决实际问题

C++中的set是一个关联容器,它包含了一组唯一的元素,并且这些元素会自动按照排序顺序进行排列

  1. 去除重复元素: 如果你有一个包含重复元素的数组或向量,你可以使用set来轻松地去除重复元素。只需将这些元素插入到set中,它们就会被自动排序并去除重复项。
#include
#include
#include 

int main() {
    std::vector nums = {1, 2, 3, 4, 5, 5, 6, 7, 8, 9, 9};
    std::set unique_nums(nums.begin(), nums.end());

    for (int num : unique_nums) {
        std::cout<< num << " ";
    }

    return 0;
}
  1. 查找元素: 使用set可以轻松地检查一个元素是否存在于集合中。set提供了find()函数,该函数可以在对数时间内查找元素。
#include
#include 

int main() {
    std::set nums = {1, 2, 3, 4, 5, 6, 7, 8, 9};

    int target = 5;
    if (nums.find(target) != nums.end()) {
        std::cout << "Found "<< target<< std::endl;
    } else {
        std::cout << "Not found "<< target<< std::endl;
    }

    return 0;
}
  1. 排序: set会自动对其中的元素进行排序。如果你需要对一组元素进行排序,可以将它们插入到set中,然后遍历set以获得已排序的元素。
#include
#include
#include 

int main() {
    std::vector nums = {9, 5, 2, 7, 3, 6, 1, 8, 4};
    std::set sorted_nums(nums.begin(), nums.end());

    for (int num : sorted_nums) {
        std::cout<< num << " ";
    }

    return 0;
}
  1. 区间查询: set还支持区间查询,例如查找大于或等于某个值的第一个元素,或查找小于或等于某个值的最后一个元素。
#include
#include 

int main() {
    std::set nums = {1, 2, 3, 4, 5, 6, 7, 8, 9};

    int lower_bound = 4;
    int upper_bound = 6;

    auto first = nums.lower_bound(lower_bound);
    auto last = nums.upper_bound(upper_bound);

    while (first != last) {
        std::cout << *first++ << " ";
    }

    return 0;
}

这些只是使用set解决实际问题的一些例子。通过使用set,你可以轻松地处理许多需要去重、查找和排序的场景。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/91218.html

相关推荐

  • c++ mysql库的数据更新与删除操作

    c++ mysql库的数据更新与删除操作

    在C++中,可以使用MySQL C++ Connector库来进行数据更新和删除操作。以下是一个简单的示例代码,展示如何使用MySQL C++ Connector库来进行数据更新和删除操作:<...

  • c++ memset_s与memset有何不同

    c++ memset_s与memset有何不同

    memset_s 和 memset 都是 C++ 中用于设置内存区域的函数,但它们之间存在一些关键差异 安全性:memset_s 是一个更安全的版本,因为它会检查目标缓冲区的大小。如...

  • c++中使用memset_s需要注意什么

    c++中使用memset_s需要注意什么

    在C++中,memset_s函数是一个安全的内存设置函数,它可以防止缓冲区溢出 包含头文件:在使用memset_s之前,请确保已经包含了正确的头文件。对于C++,应该包含头文...

  • c++ memset_s如何安全清零内存

    c++ memset_s如何安全清零内存

    在C++中,memset_s是一个安全的方法来清零内存
    #include
    #include int main() { char buffer[100]; // 填充缓冲区 for (int i = 0; i< sizeof(buffer)...

  • C++中set集合与其他容器的比较

    C++中set集合与其他容器的比较

    C++ 标准库提供了多种容器,用于存储和管理数据。std::set 是其中之一,它是一个关联容器,包含一组唯一的元素,并按照特定的排序规则进行排序。以下是 std::set...

  • 如何使用C++的set集合实现数据去重

    如何使用C++的set集合实现数据去重

    在C++中,set是一个关联容器,它包含一组唯一的对象。每个元素在插入时自动按键(key)排序。set不支持下标运算符([]),因为元素没有与其关联的键值。要访问se...

  • 为什么C++中没有内置的println函数

    为什么C++中没有内置的println函数

    C++ 是一种通用编程语言,它提供了丰富的库和功能,以满足各种应用程序的需求 标准库的设计原则:C++ 标准库遵循“只有当必要时才标准化”的原则。这意味着,只有...

  • C++中没有println函数,如何实现类似功能

    C++中没有println函数,如何实现类似功能

    在 C++ 中,可以使用 std::cout 和 std::endl 来实现类似于 Java 中 System.out.println() 的功能。下面是一个简单的示例:
    #include int main() { std::co...