gpt4 book ai didi

c++ - 如何将结构成员数组作为参数传递给函数?

转载 作者:搜寻专家 更新时间:2023-10-31 01:47:39 28 4
gpt4 key购买 nike

这是我的问题:我有一个结构:

struct point
{
int x;
int y;
};

然后我有一个数组:

for (int i = 0;i < n;i++)
{
arr[i].x=rand() % n + 1;
}

我定义了 quicksort 函数如下:

 void quicksort(int *a, int left, int right);

我想通过 X 坐标对点进行排序,所以我调用了 quicksort:

quicksort(arr.x, 0, n-1);

这是错误信息:

error: request for member 'x' in 'arr', which is of non-class type 'point [(((unsigned int)(((int)n) + -0x000000001)) + 1)]'

抱歉,如果问题太愚蠢或表述不当,事实是我是新手,我真的很愿意尽可能多地学习,非常感谢您的帮助!

最佳答案

如果你总是想按x排序,那么你可以把它硬编码到排序函数中,然后只传递一个指向数组的指针来排序:

void quicksort(point * arr, int left, int right) {
// test points with
// if (arr[i].x < arr[j].x) {/* i sorts before j */}
}

quicksort(arr, 0, n-1);

要指定要排序的类成员,您需要指向成员的指针,而不是指针;像这样的东西:

void quicksort(point * arr, int point::*member, int left, int right){
// test points with
// if (arr[i].*member < arr[j].*member) {/* i sorts before j */}
}

quicksort(arr, &point::x, 0, n-1);

更一般地说,您可以按照 std::sort 的示例并接受任何比较仿函数:

template <typename RandIter, typename Compare>
void quicksort(RandIter begin, RandIter end, Compare compare) {
// test points with
// if (compare(*it1, *it2)) {/* *it1 sorts before *it2 */}
}

quicksort(arr, arr+n,
[](point const &lhs, point const &rhs) {return lhs.x < rhs.x;});

当然,除非您正在学习如何实现排序算法,否则只需使用 std::sort

关于c++ - 如何将结构成员数组作为参数传递给函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18963272/

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