Грабли: различия между версиями
Перейти к навигации
Перейти к поиску
Ctrlalt (обсуждение | вклад) |
Ctrlalt (обсуждение | вклад) |
||
Строка 48: | Строка 48: | ||
=== В <ctype.h> функции классификации символов (такие как isupper()) могут возвращать не только 0 и 1 === | === В <ctype.h> функции классификации символов (такие как isupper()) могут возвращать не только 0 и 1 === | ||
* [http://ideone.com/GUKcBa ideone.com/GUKcBa] | * [http://ideone.com/GUKcBa ideone.com/GUKcBa] | ||
=== Следите за инвалидацией итераторов, указателей и ссылок === | |||
{| class="wikitable" | |||
|+ Что инвалидируется в худшем случае при вызове методов вставки и удаления | |||
| | |||
| insert | |||
| erase | |||
| push_back | |||
| pop_back | |||
| push_front | |||
| pop_front | |||
|- | |||
| vector | |||
| все итераторы (при реаллокации)<br>все указатели<br>все ссылки | |||
| итераторы от места удаления до конца<br>указатели от места удаления до конца<br>ссылки от места удаления до конца | |||
| все итераторы<br>все указатели<br>все ссылки | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| | |||
| | |||
|- | |||
| deque | |||
| все итераторы (при вставке в начало/конец) | |||
| все итераторы<br>все указатели<br>все ссылки | |||
| все итераторы | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| все итераторы | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
|- | |||
| list | |||
| (нет инвалидаций) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| (нет инвалидаций) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| (нет инвалидаций) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
|- | |||
| set | |||
| (нет инвалидаций) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| map | |||
| (нет инвалидаций) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| unordered_set | |||
| все итераторы (при перехешировании) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| | |||
| | |||
| | |||
| | |||
|- | |||
| unordered_map | |||
| все итераторы (при перехешировании) | |||
| итератор на удаляемый элемент<br>указатель на удаляемый элемент<br>ссылка на удаляемый элемент | |||
| | |||
| | |||
| | |||
| | |||
|} | |||
== Разное == | == Разное == |
Версия от 16:48, 10 февраля 2021
Ввод и вывод
cin/cout работает медленнее scanf/printf
- Codeforces — Ввод/вывод в C++
- Codeforces — Снова про ввод/вывод в C++
- Habrahabr — Насколько медленны iostreams?
endl сбрасывает буфер вывода после перевода строки
Различные компиляторы по-разному округляют вещественные числа с последним дробным разрядом 5
Аккуратнее с %lld и %I64d: %lld предпочтительнее
- %lld некорректно работает в очень древних Visual C++, а также в GNU C++ (MinGW) под Windows XP (например, на acmp.ru).
- %I64d некорректно работает в GNU C++ под Linux (то есть почти везде).
- Codeforces: 1, 2
- CodeChef
Вещественные числа
Вещественные числа нужно использовать с осторожностью; функции <math.h> работают с вещественными числами
- ideone.com/yBUC04
- ideone.com/4wnPS0
- isocpp.org — Why doesn’t my floating-point comparison work?
- Макконнелл С. Совершенный код / С. Макконнелл. — М.: Русская редакция, 2010. — 896 с. — П. 12.3. «Числа с плавающей запятой», с. 286
- Codeforces — Weird bug with pow?
- Codeforces — Работа с вещественными числами
Если не хватает точности double
- Меняем все double на long double;
- Меняем все вызовы cstdio (scanf/printf) на вызовы iostream (cin/cout);
- Добавляем l ко всем функциям cmath (sqrt -> sqrtl, atan2 -> atan2l);
- Сдаём под g++.
Особенности функций
Метод .size() у контейнеров STL возвращает беззнаковое число
Метод .count() у multiset/multimap работает за линию от количества подсчитываемых элементов
- Актуально для multiset, unordered_multiset, multimap, unordered_multimap
В <ctype.h> функции классификации символов (такие как isupper()) могут возвращать не только 0 и 1
Следите за инвалидацией итераторов, указателей и ссылок
insert | erase | push_back | pop_back | push_front | pop_front | |
vector | все итераторы (при реаллокации) все указатели все ссылки |
итераторы от места удаления до конца указатели от места удаления до конца ссылки от места удаления до конца |
все итераторы все указатели все ссылки |
итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
||
deque | все итераторы (при вставке в начало/конец) | все итераторы все указатели все ссылки |
все итераторы | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
все итераторы | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
list | (нет инвалидаций) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
(нет инвалидаций) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
(нет инвалидаций) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
set | (нет инвалидаций) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
||||
map | (нет инвалидаций) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
||||
unordered_set | все итераторы (при перехешировании) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
||||
unordered_map | все итераторы (при перехешировании) | итератор на удаляемый элемент указатель на удаляемый элемент ссылка на удаляемый элемент |
Разное
В <math.h> Visual C++ уже заняты глобальные имена j0, j1, jn, y0, y1, yn
- Timus — Как писать решения на C/C++ (Раздел «Особенности компилятора по сравнению с другими 32-битными компиляторами C/C++»)
Приоритетная очередь работает быстрее, чем сет
- Несмотря на равную асимптотику, приоритетная очередь имеет много меньшую константу, чем сет. Поэтому некоторые задачи можно сдать только с приоритетной очередью.
Аккуратнее с map[key] = map.size()
- В результате при изначально пустом map значение map[key] может оказаться равным 1. Ситуацию вроде как исправили в C++17.
- Unspecified behaviour in C++ when adding to map