gpt4 book ai didi

c++ - 在排序数组 c 之前保留索引

转载 作者:行者123 更新时间:2023-11-28 03:22:55 25 4
gpt4 key购买 nike

您好,我在排序之前将此代码用于我的商店索引,但是当我在此行中编译时::

    [&](size_t a, size_t b){ return values[a] < values[b]; }

,对我说错误:

        Multiple markers at this line
- expected primary-expression before
'[' token
- expected primary-expression before
']' token
- expected primary-expression before
'a'
- expected primary-expression before
'b'

template <typename T>
std::vector<size_t> ordered(std::vector<T> const& values) {
std::vector<size_t> indices(values.size());
std::iota(indices.begin(), indices.end(), static_cast<size_t>(0));

std::sort(
indices.begin(), indices.end(),
[&](size_t a, size_t b){ return values[a] < values[b]; }

);
return indices;
}

第二个问题,当我有经典的一维输入数组时,我该如何调用

最佳答案

[...](...) { ... } 语法是一个 lambda 表达式,是 C++11 的一个特性。您需要确保您使用的是支持它们的编译器。一些编译器提供了一个开关来启用 C++ 功能(-std=c++0x for GCC)。

如果您想在普通数组上使用 std::sort,请使用:

std::sort(array, array + array_size, comp);

或者,您可以让代码不知道您使用的是容器还是数组。其中 ac 是数组或容器:

std::sort(std::begin(ac), std::end(ac), comp);

关于c++ - 在排序数组 c 之前保留索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14963840/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com