- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
// https://habr.com/post/428846/
// Работа со строками на этапе компиляции в современном C++
// Определим статическую строку как массив символов, для удобства будем считать, что строка всегда оканчивается нулевым символом:
template<size_t Size>
using static_string = std::array<const char, Size>;
constexpr static_string<6> hello = {'H', 'e', 'l', 'l', 'o', '\0'};
constexpr auto hello = make_static_string("hello");
// Здесь нам поможет одна из форм вариативного шаблона, которая позволяет развернуть
// шаблонные аргументы как индексы для агрегатной инициализации нашей статической
// строки из строкового литерала:
template<size_t Size, size_t ... Indexes>
constexpr static_string<sizeof ... (Indexes) + 1> make_static_string(const char (& str)[Size]) {
return {str[Indexes] ..., '\0'};
}
constexpr auto hello = make_static_string<0, 1, 2, 3, 4>("hello"); // hello == "hello"
// ...
//Будем сравнивать строки посимвольно, пока не выявим различия, либо не достигнем конца хотя бы одной из строк.
// Поскольку constexpr for еще не изобрели, воспользуемся рекурсией и тернарным оператором:
template<size_t Size1, size_t Size2>
constexpr int static_string_compare(
const static_string<Size1>& str1,
const static_string<Size2>& str2,
int index = 0) {
return index >= Size1 && index >= Size2 ? 0 :
index >= Size1 ? -1 :
index >= Size2 ? 1 :
str1[index] > str2[index] ? 1 :
str1[index] < str2[index] ? -1 :
static_string_compare(str1, str2, index + 1);
}
j123123 20.11.2018 08:35 # +1
такая-то рекурсия, so functional!
j123123 20.11.2018 08:46 # +1
j123123 20.11.2018 08:53 # +1
j123123 20.11.2018 08:41 # 0
Детальное рассмотрение этого варианта выходит за рамки статьи, буду рад, если кто-то из читателей говнокода займется доведением его до ума.
bormand 20.11.2018 10:36 # +1
j123123 20.11.2018 10:49 # +2
bormand 20.11.2018 10:59 # +1
j123123 20.11.2018 23:37 # +1
Проще всего сделать для брейнфака, под него уже есть компилятор сишечки какой-то https://esolangs.org/wiki/C2BF - можно этот компилятор в компилтайм-крестопишушню переписать (компилтайм-интерпретатор брейнфака на крестопарашных темплейтах и констэкспрах вообще легко пишется)
vistefan 20.11.2018 12:12 # 0
Царский анролл
j123123 20.11.2018 11:43 # 0
Достаточно посмотреть на комменты с отрицательным рейтингом:
https://habr.com/post/428846/#comment_19327348
https://habr.com/post/428846/#comment_19327790
Типа если честно и объективно заявить что эти ваши шаблоны с констэкспрами полное говно, и в жопу себе их засуньте, то тебя сразу крестоуебки карму заминусуют. Охлократия одним словом
guest8 21.11.2018 00:15 # −999
6A9lHuCT 21.11.2018 00:36 # −102
Напитки из черной головки
guest8 21.11.2018 00:38 # −999
rajluTo3Huk 21.11.2018 00:41 # 0
guest8 21.11.2018 00:43 # −999
rajluTo3Huk 21.11.2018 00:51 # 0
guest8 21.11.2018 00:54 # −999
rajluTo3Huk 21.11.2018 01:00 # 0
guest8 21.11.2018 01:11 # −999
guest8 21.11.2018 01:20 # −999
guest8 21.11.2018 01:21 # −999
blackray 21.11.2018 01:34 # 0
p.s. Bormand, залогинься.
guest8 21.11.2018 01:36 # −999
blackray 21.11.2018 01:39 # −1
http://gaymas.com/wp-content/uploads/seducir-gay.jpg
Не благодари.
rajluTo3Huk 21.11.2018 01:48 # +1
guest8 21.11.2018 01:52 # −999