ещё способы поизвращаться в этом быдлокоде?)
#include <iostream>
#include <algorithm>
#include <string_view>
#include <ranges>
#include <list>
#include <functional>
template <std::integral T>
constexpr std::list<T> reverse(const std::list<T>& lst) {
std::list<T> reversed_lst;
std::ranges::copy(lst, std::ranges::front_inserter(reversed_lst));
return reversed_lst;
}
template <std::size_t... Ns>
constexpr auto get_indices(std::index_sequence<Ns...>) {
return std::list<std::size_t>{Ns...};
}
template <std::size_t N>
constexpr auto generate_indices() {
return get_indices(std::make_index_sequence<N>{});
}
template <typename T>
constexpr auto reverse_string(const T& str) {
constexpr std::size_t str_length = std::ranges::size(str);
constexpr auto indices = reverse(generate_indices<str_length>());
std::list<typename T::value_type> reversed_str;
std::ranges::transform(indices, std::back_inserter(reversed_str),
[&str](std::size_t index) { return str[index]; });
return reversed_str;
}
int main() {
constexpr auto hello_str = reverse_string(std::string_view{
"dlrow ,olleH"
});
auto hello_lambda = [](const std::list<char>& str) {
std::ranges::for_each(str, [](char c) {
std::cout << c;
});
};
std::function<void(const std::list<char>&)> hello_func = hello_lambda;
hello_func(hello_str);
return 0;
}
Все понятно, но нафига?
Но зачем же здесь std::list?
Обсуждают сегодня