You can create a "proxy" function that initializes your vector. This uses template deduction to find the size of the array automatically.
template <typename T, std::size_t N>
std::vector<int*> init_vector(T (&foo)[N])
{
std::vector<int*> vec;
for (std::size_t i = 0; i < N; ++i)
{
vec.push_back(&foo[i]);
}
return vec;
}
int main()
{
int foo[] {1, 2, 3, 4, 5};
const std::vector<int*> vec = init_vector(foo);
for (auto v : vec) std::cout << *v << " ";
}
Alternatively, if you're able to use Boost, you can use boost::make_transform_iterator:
int* convert_to_ptr(int& i)
{
return &i;
}
int main()
{
int foo[] {1, 2, 3, 4, 5};
const std::vector<int*> vec {
boost::make_transform_iterator(std::begin(foo), convert_to_ptr),
boost::make_transform_iterator(std::end(foo), convert_to_ptr)
};
std::vector's iterator ctor I believe, which won't work cause I'm constructing astd::vectorofint*s not astd::vectorofints.boost:: transform_iteratorto adaptbegin(foo)andend(foo).