Просмотр сообщений
|
Страниц: 1 2 3 [4] 5 6 ... 217
|
47
|
Программирование / С/C++ / Re: Compile-time определение реверсивности итератора (reverse_iterator)
|
: Апрель 15, 2021, 16:46
|
 Так всегда было, неперемещаемость только для erase, для вставок и remove "пионерский привет" (rehash) хэш (обычно) это массив линкед-листов. при реаллокации массива, внезапно, адреса (и ссылки на элементы) нодов линкед листов не меняются - эту гарантию даёт, например, std::unordered_map. можно действительно хэш реализовать другими способами, и тогда при раллокации адреса могут поехать, но в qt5 он был старым-добрым массивом линкед-листов и давал гарантию при insert'e (по крайней мере, оно работало на практике) Но как минимум странно имея имплементацию "по стандарту" менять ее на другую которую захотела левая пятка, поломав кучу кода. При переходе на qt6 код ломается, и самое простое решение - выкинуть QHash нафиг и использовать std::unordered_map. Не стоит так "хвост распускать"  , дойдет до дела (выше) - будет обычная история  Просто ваши задачи требуют неадекватного количества времени чтобы понять вообще в чем задача - требования меняются каждую страницу потому что вы их "забыли" указать, но предложенное решение им (конечно же!) не удовлетворяет. -я хочу сделать кнопку чтобы приложение закрывлось -вот кнопка -мне круглую надо -окей -и красную -окей -и чтобы шрифт зеленый -ооок -и чтобы диалог появлялся -вот диалог -да ты просто тупой, вот я взял и написал сразу круглую красную кнопку с зеленым текстом и диалогом а вы все форумом хрень какую-то предлагали. зато в шаблоны умеете!
|
|
|
49
|
Программирование / С/C++ / Re: Compile-time определение реверсивности итератора (reverse_iterator)
|
: Апрель 15, 2021, 16:14
|
Дык это я как раз строчку с "букваря" (документации по QHash) взял. Там написано, что "по стандарту" int не обязан нулём инициализироваться, поэтому для хэша они это "сами заимплементировали".
Ну кутешные контейнеры пишут такие же специалисты как те которые в итераторах не могут разобраться=) В Qt6 например QHash не обеспечивает стабильность ссылок при вставке что ломает тонну кода. Вы читайте cppreference - там требование к T чтобы он был default-constructible для operator[]. Интересно, зачем надо default-constructible кроме как чтобы позвать T() (подсказка - int a; дефолт ктор не зовет)
|
|
|
50
|
Программирование / С/C++ / Re: Compile-time определение реверсивности итератора (reverse_iterator)
|
: Апрель 15, 2021, 15:53
|
Почти хорошо, т.к. *But for primitive types like int and double, as well as for pointer types, the C++ language doesn't specify any initialization; in those cases, Qt's containers automatically initialize the value to 0.
Кутешные контейнеры тут ни при чем - если элемента нет, вставляется default-constructed value, что для int'а 0 по стандарту. default-constructed value != uninitialized variable. Но это же букварь читать надо, тонкости языка знать, это не циклы с индексами писать=) Но только если в хэше уже раньше был 0-й ключ, то он превратится в 100, а не в 1... Понимаю, что пошла уже софистика, но возможно "джун" был не совсем туп  Ну это действительно софистика, потому что исходный код считал с нуля но зачем-то делал 3 лукапа.
|
|
|
55
|
Разное / Говорилка / Re: Геометрия (задачки)
|
: Апрель 06, 2021, 14:29
|
В треугольник вписано 3 квадрата площадями 4,36,9. Найти площадь треугольника. Запрещено применять тригонометрию и теорему Пифагора, векторную алгебру, аналитическую геометрию.
Ну не очень ясно, мне кажется я все равно пользуюсь подобием. Можно достроить аналогичный треугольник, скажем, справа, получим параллелограмм. Дальше можно заметить, что если перекинуть "правый" кусок (треугольник) параллелогамма налево, то получим прямоугольник размера вдвое больше исходного треугольника. А дальше вопрос, чем можно пользоваться - то есть как вычислить высоту и ширину. С высотой просто - это 6 + 4 (высота левого большого треугольника). С шириной хуже - надо понять что правые треугольники равнобедренные, а значит ширина правого куска тоже 3. Слева надо учесть что катеты относятся как 2 к 1 (но это же подобие?) и что ширина левого кусочка - 1. Итого (6 + 4) * (1 + 2 + 6 + 3 + 3) / 2 = 75 upd: игнорируйте, фигню написал
|
|
|
|
|