std::fill_n — cppreference.com
Материал из cppreference.com
<tbody> </tbody>
|
|
(до C++11) (начиная с C++11) |
|
Если count>0, присваивает заданное значение value первым count элементам в диапазоне, начинающемся с first. Иначе ничего не делает.
Параметры
| first | — | начало диапазона изменяемых элементов |
| count | — | число изменяемых элементов |
| value | — | присваиваемое значение |
| Требования к типам | ||
-OutputIt должен соответствовать требованиям OutputIterator.
| ||
Возвращаемое значение
(Нет) (до C++11)
Если count>0, итератор на элемент, следующий за последним элементом, которому было присвоено значение, иначе — first. (начиная с C++11)
Сложность
Ровно count присваиваний, если count>0.
Возможная реализация
template<class OutputIt, class Size, class T> OutputIt fill_n(OutputIt first, Size count, const T& value) { for (Size i = 0; i < count; i++) { *first++ = value; } return first; }
Пример
Следующий код использует fill_n(), чтобы присвоить значение -1 первой половине вектора целых чисел, далее вставляет -1 в конце вектора:
#include <algorithm> #include <vector> #include <iostream> #include <iterator> int main() { std::vector<int> v1{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; std::fill_n(begin(v1), 5, -1); for(const auto &it: v1) { std::cout << it << " "; } std::cout << "\n"; std::fill_n(back_inserter(v1), 5, -1); for(const auto &it: v1) { std::cout << it << " "; } std::cout << "\n"; }
Вывод:
-1 -1 -1 -1 -1 5 6 7 8 9 -1 -1 -1 -1 -1 5 6 7 8 9 -1 -1 -1 -1 -1
См. также
| присваивает диапазону элементов определённое значение (шаблон функции) [править] |