std::transform是C++ STL中用于元素转换的核心算法,通过一元或二元操作将输入范围的元素映射到输出范围。它支持两种形式:第一种对单个范围应用一元操作,如将整数向量平方并存入新向量;第二种结合两个输入范围进行二元操作,如对应元素相加。配合lambda表达式,代码更简洁高效。该算法不仅适用于基本类型,还可处理自定义对象,例如将Person对象转换为描述字符串,展现出强大的通用性和灵活性。

STL算法在C++中实现元素转换主要依赖于
std::transform
std::transform
std::transform
第一种形式接受一个输入范围(由起始和结束迭代器定义)、一个输出迭代器以及一个一元操作(unary operation)。这意味着你可以把一个容器(比如
std::vector<int>
#include <vector>
#include <algorithm>
#include <iostream>
#include <numeric> // 为了std::iota,方便填充数据
int main() {
std::vector<int> original_numbers(5);
std::iota(original_numbers.begin(), original_numbers.end(), 1); // 填充1, 2, 3, 4, 5
std::vector<int> squared_numbers(original_numbers.size());
// 使用lambda表达式进行平方转换
std::transform(original_numbers.begin(), original_numbers.end(),
squared_numbers.begin(),
[](int n) { return n * n; });
std::cout << "Original numbers: ";
for (int n : original_numbers) {
std::cout << n << " ";
}
std::cout << std::endl;
std::cout << "Squared numbers: ";
for (int n : squared_numbers) {
std::cout << n << " ";
}
std::cout << std::endl;
// 也可以原地转换,如果输出范围和输入范围相同,但要注意原地修改的副作用
std::vector<int> numbers_to_double = {10, 20, 30};
std::transform(numbers_to_double.begin(), numbers_to_double.end(),
numbers_to_double.begin(), // 输出到原位置
[](int n) { return n * 2; });
std::cout << "Doubled numbers (in-place): ";
for (int n : numbers_to_double) {
std::cout << n << " ";
}
std::cout << std::endl;
return 0;
}第二种形式则更强大一些,它接受两个输入范围、一个输出迭代器以及一个二元操作(binary operation)。这允许你同时处理来自两个不同序列的元素,并将它们结合起来。比如,我想把两个向量对应位置的元素相加,然后把结果放到第三个向量里:
立即学习“C++免费学习笔记(深入)”;
#include <vector>
#include <algorithm>
#include <iostream>
#include <numeric>
int main() {
std::vector<int> vec1 = {1, 2, 3};
std::vector<int> vec2 = {4, 5, 6};
std::vector<int> sum_vec(vec1.size()); // 确保输出容器有足够空间
// 使用lambda表达式进行元素相加
std::transform(vec1.begin(), vec1.end(),
vec2.begin(), // 第二个输入范围的开始
sum_vec.begin(), // 输出范围的开始
[](int a, int b) { return a + b; });
std::cout << "Vector 1: ";
for (int n : vec1) std::cout << n << " ";
std::cout << std::endl;
std::cout << "Vector 2: ";
for (int n : vec2) std::cout << n << " ";
std::cout << std::endl;
std::cout << "Sum vector: ";
for (int n : sum_vec) std::cout << n << " ";
std::cout << std::endl;
return 0;
}这两种形式,尤其配合C++11引入的lambda表达式,简直是如虎添翼。以前可能需要手写循环,现在一行
std::transform
std::transform
当我们面对的不是简单的
int
double
std::transform
std::vector<Person>
Person
name
age
Person
std::vector<std::string>
"Name: [name], Age: [age]"
这听起来有点复杂,但
std::transform
#include <vector>
#include <algorithm>
#include <iostream>
#include <string>
#include <iterator> // For std::back_inserter
struct Person {
std::string name;
int age;
// 构造函数方便初始化
Person(std::string n, int a) : name(std::move(n)), age(a) {}
};
int main() {
std::vector<Person> people = {
{"Alice", 30},
{"Bob", 24},
{"Charlie", 35}
};
std::vector<std::string> person_descriptions;
// 预留空间是个好习惯,避免多次重新分配,但这里使用back_inserter可以省略
// person_descriptions.reserve(people.size以上就是C++如何使用STL算法实现元素转换的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号