举个C++的例子
时间: 2023-07-11 12:14:24 浏览: 89
好的,一个简单的C++例子是使用`std::sort`函数对一个整数数组进行排序,该函数需要一个比较函数作为回调函数,以便在排序过程中进行比较。下面是代码示例:
```c++
#include <iostream>
#include <algorithm>
#include <vector>
bool compare(int a, int b) {
return a < b;
}
int main() {
std::vector<int> nums = {3, 6, 1, 8, 2};
std::sort(nums.begin(), nums.end(), compare);
for (int i = 0; i < nums.size(); i++) {
std::cout << nums[i] << " ";
}
return 0;
}
```
在这个例子中,`compare`函数是作为回调函数传递给`std::sort`函数。`compare`函数接收两个整数参数,并返回一个布尔值,表示第一个参数是否小于第二个参数。当`std::sort`函数进行排序时,它将使用`compare`函数进行比较。在这个例子中,`nums`向量将被排序,并且输出结果为:`1 2 3 6 8`。
相关问题
举个C++例子
好的,这里是一个使用 fftw_plan_dft_1d() 函数创建一维 DFT 计划并执行的 C++ 代码示例:
```c++
#include <iostream>
#include <fftw3.h>
using namespace std;
int main() {
int n = 8;
fftw_complex *in, *out;
fftw_plan plan;
in = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * n);
out = (fftw_complex*) fftw_malloc(sizeof(fftw_complex) * n);
plan = fftw_plan_dft_1d(n, in, out, FFTW_FORWARD, FFTW_ESTIMATE);
for(int i = 0; i < n; i++) {
in[i][0] = i; // 实部赋值
in[i][1] = 0; // 虚部赋值
}
fftw_execute(plan);
for(int i = 0; i < n; i++) {
cout << out[i][0] << " + " << out[i][1] << "i" << endl;
}
fftw_destroy_plan(plan);
fftw_free(in);
fftw_free(out);
return 0;
}
```
该程序创建了一个长度为 8 的输入信号和输出信号数组,使用 fftw_plan_dft_1d() 函数创建了一个计划,然后对输入信号进行赋值,并使用 fftw_execute() 函数执行计划,最后输出变换后的结果。最后需要使用 fftw_destroy_plan() 函数销毁计划并释放内存。
什么是生成器函数,举个C++例子
生成器函数是一种特殊的函数,它可以生成一个序列(例如数字、字符串等),而不是一次性返回整个序列。当需要处理大量数据时,这种生成器函数可以提供更高效的解决方案,因为它可以按需生成数据,而不是一次性生成整个序列。
在 C++ 中,使用 `yield` 关键字可以创建一个生成器函数。`yield` 关键字用于将一个值返回给调用者,并且暂停函数的执行,等待下一次调用。下面是一个简单的使用 `yield` 关键字的 C++ 生成器函数的例子:
```c++
#include <iostream>
#include <vector>
std::vector<int> generator(int start, int end) {
for (int i = start; i <= end; ++i) {
co_yield i;
}
}
int main() {
for (auto x : generator(1, 5)) {
std::cout << x << " ";
}
std::cout << std::endl;
return 0;
}
```
在上面的代码中,`generator` 函数使用 `co_yield` 关键字生成从 `start` 到 `end` 的整数序列。在 `main` 函数中,我们通过循环遍历生成器函数返回的序列,并将每个值输出到控制台。需要注意的是,使用生成器函数需要使用协程(coroutine)支持,因此需要在编译时启用协程支持。
阅读全文