gpt4 book ai didi

C++ 创建一个以数组为参数的泛型函数

转载 作者:行者123 更新时间:2023-11-30 01:35:35 25 4
gpt4 key购买 nike

我是 C++ 新手。我是来自 C 的学生。

我的目标是编写一个简单的函数,它接受一个数组作为参数。我成功了,但我对结果不满意。

主要.cpp

#include <array>
#include <iostream>
#include "MyMath.hpp"

int main()
{
std::array<int, 5> array = {1, 2, 3, 5, 4};

MyMath::sortIntArray(array);
std::cout << array.at(3) << std::endl;
return 0:
}

我的数学.hpp

#include <array>

class MyMath {
public:
static void sortIntArray(std::array<int, 5> &array)
{
array.at(3) = 99;
}
}

我创建了一个类来包含我的函数,因为这是学校的编码风格。上面代码的问题是我在函数的参数中写了数组的大小。 “如果我想对包含 500 个数字的数组进行排序怎么办?”

1)所以我的问题是:编写相同函数而不必编写数组大小的最佳方法是什么?

2)我已经做了一些研究并且我知道 std::vector 但是当你想创建一个固定大小的数组时使用 std::array 不是更合适吗?

3)我可以使用 C-Style 数组解决我的问题:通过将数组的最后一个元素设置为 NULL 或将大小作为第二个参数发送。但是对数组和字符串使用等效类不是更合适吗? (std::array/std::vector/std::string 并且几乎不再使用 int[])

4) 我见过可以让我成功实现目标的"template",但是在编写排序算法的第二个小函数后,我注意到我必须为每个采用 std::array 的函数使用模板作为疯狂的参数。

如果答案是简单地使用 std::vector 或 int[]。我需要 std::array 吗? (因为在我看来它并不比 int[] 好,所以我可以像 3 中所说的那样用 int[] 解决问题)。我无法用 std::array 解决问题)

有 4 个问题。对于我对这种语言的一般理解,我认为考虑回答所有 4 个问题很重要(即使它只是一个很短的句子)。提前谢谢你。

最佳答案

std::sort的界面.它不是采用具体的容器类型,而是采用通用的 [start, end)迭代器对。然后如果调用者想要对一个 vector 进行排序,他们可以传入一对 std::vector<int>::iterator_type。秒。如果他们想对 5 个整数的数组进行排序,他们可以传入 std::array<int, 5>::iterator_type。 .如果他们想对 C 风格的数组进行排序,他们可以传入 int*

关于C++ 创建一个以数组为参数的泛型函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53839652/

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