C++ std::list 的 remove_if方法

在C++ STL 中,std::list 是一个双向链表容器,提供了 remove_if 方法用于在列表中移除满足特定条件的元素。remove_if 方法接受一个谓词函数(predicate function)作为参数,用于判断是否移除当前元素。下面是一个示例代码,演示如何使用 remove_if 方法从 std::list 中移除满足特定条件的元素:

cpp 复制代码
#include <iostream>
#include <list>
#include <algorithm>

// 定义一个谓词函数,用于判断是否移除元素
bool isOdd(int num) {
    return num % 2 != 0;
}

int main() {
    std::list<int> myList = {1, 2, 3, 4, 5, 6, 7, 8, 9};

    // 移除列表中的奇数元素
    myList.remove_if(isOdd);

    // 打印移除元素后的列表
    for (const auto& elem : myList) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;

    return 0;
}

在这个示例中:

  • isOdd 是一个谓词函数,用于判断一个整数是否是奇数。
  • myList.remove_if(isOdd) 使用 remove_if 方法移除列表中所有奇数元素。
  • 最后通过循环遍历列表,打印移除元素后的列表内容。

你可以根据自己的需求定义不同的谓词函数,用于判断是否移除特定的元素。这是使用 std::listremove_if 方法的一个简单示例。

相关推荐
小欣加油3 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
星恒随风4 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
浪客灿心4 小时前
项目篇:模块设计与实现
数据库·c++
牛油果子哥q4 小时前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
为何创造硅基生物6 小时前
独占指针的创建std::make_unique 本身自带堆出现
c++
kyle~6 小时前
ROS 2 与 Isaac Sim 联合仿真(一)体系架构、环境选型与基础通信闭环
c++·机器人·nvidia·仿真·ros2
努力努力再努力wz7 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂7 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
起床困难户5758 小时前
条款20:协助完成返回值优化
c++
啦啦啦啦啦zzzz8 小时前
算法总结(二分查找、双指针)
c++·算法