Передача и возврат массива

Мне было интересно .. Всякий раз, когда я имею дело с массивами, когда я должен их разрезать, или отсортировать, или что-то еще, а затем вернуть его, я передаю его функции void, такой как f(array, length, newarray), и в объявлении функции у меня есть void f(T *array, int length, T *&new array). Есть лучший способ это сделать?

Вот код, я хочу удалить повторы из массива:

template<class T>
void eliminate(T *niz, int duzina, T *&podniz)
{
    int ind;
    podniz = new T[duzina];
    for (int i = 0; i<duzina; i++)
    {
        ind = 0;
        for (int j = i; j<duzina; j++)
        {
            if (niz[i] == niz[j])ind++;
        }
        if (ind == 1)podniz[nova++] = niz[i];
    }
}

А что насчет функции, возвращающей новый массив? Что-то вроде T* f(T* array, int length);

Robert Kock 23.04.2018 14:46

Определите «лучше».

Johnny Mopp 23.04.2018 14:46

Поделитесь кодом

rak007 23.04.2018 14:46

Да, есть. Используйте std::array или std::vector.

Ron 23.04.2018 14:47

Это слишком общий вопрос. Возвращать новый массив «функционально» лучше.

glhrmv 23.04.2018 14:47

@Ron: Однако вырезать элементы из std::array немного сложно;)

MSalters 23.04.2018 15:02

@MSalters Я добавил код ..

Lazar Šćekić 23.04.2018 15:03

@MSalters Действительно, я пропустил это при первом чтении.

Ron 23.04.2018 15:04
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
8
77
2

Ответы 2

Конечно. Вы можете использовать указатели и передавать массив по ссылке на функцию. Затем манипулируйте массивом и возвращайтесь из функции с типом void, т.е. нет необходимости возвращать массив, поскольку он передается по ссылке.

В C++ передача массива по ссылке означает нечто иное, чем передача указателя.

Peter 23.04.2018 14:52

Как уже отмечалось в комментариях, вам действительно нужен std::vector.

Основная проблема с вашим кодом заключается в том, что невозможно определить, сколько элементов вывода фактически инициализировано. А доступ к неинициализированным элементам - это Undefined Behavior, поэтому вы возвращаете вызывающему объекту бомбу замедленного действия.

С std::vector<T> eliminate(std::vector const&) таких сомнений нет. Возвращенный вектор содержит ровно .size() элементов.

Vector также безопасен в отношении исключений. В вашем коде будет утечка памяти, если конструктор копирования T выдает, например на std::bad_alloc.

У меня есть глобальная переменная для подсчета количества элементов, поскольку, как вы видите, она не инициализирована в самой функции.

Lazar Šćekić 23.04.2018 15:10

Спасибо, я буду придерживаться std :: vector, как только закончу курс, где мы научимся кодировать std :: vector.

Lazar Šćekić 23.04.2018 15:12

Другие вопросы по теме