Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🤝40👍16🔥11❤1
This media is not supported in your browser
VIEW IN TELEGRAM
Он собрал в себе статьи с реализациями на C++, пошаговыми объяснениями и анализом сложности. Отлично подойдёт для тех кто хочет вспомнить материал для олимпиадного программирования и технических собеседований.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍22❤7🔥4
Безопасно преобразуем строку в число!
Сейчас научимся превращать строку в целое число так, чтобы программа не упала при ошибке. Это пригодится при чтении пользовательского ввода, разборе конфигов и CLI-параметров.
Подключим нужные библиотеки — всё уже есть в стандартной поставке:
Допустим, у нас есть строка, которую мы хотим превратить в
Если строка содержит лишние символы или слишком большое число, преобразование может вызвать ошибку.
Пишем аккуратную проверку с помощью
Добавим обработку ошибок:
Возможный результат при запуске (если строка содержит мусор):
🔥 Таким образом ты можешь безопасно превращать строки в числа — с учётом всех ошибок и без крашей программы.
📣 C++ Ready | #практика
Сейчас научимся превращать строку в целое число так, чтобы программа не упала при ошибке. Это пригодится при чтении пользовательского ввода, разборе конфигов и CLI-параметров.
Подключим нужные библиотеки — всё уже есть в стандартной поставке:
#include <iostream>
#include <string>
Допустим, у нас есть строка, которую мы хотим превратить в
int
:std::string raw = "42abc";
Если строка содержит лишние символы или слишком большое число, преобразование может вызвать ошибку.
Пишем аккуратную проверку с помощью
try-catch
— если что-то пойдёт не так, мы это отловим:try {
int value = std::stoi(raw);
std::cout << "Число: " << value << '\n';
Добавим обработку ошибок:
} catch (const std::invalid_argument&) {
std::cout << "Некорректный ввод: не число\n";
} catch (const std::out_of_range&) {
std::cout << "Число вне диапазона int\n";
}
Возможный результат при запуске (если строка содержит мусор):
Некорректный ввод: не число
🔥 Таким образом ты можешь безопасно превращать строки в числа — с учётом всех ошибок и без крашей программы.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍25❤9🤝5👎1
Например,
код 200
означает, что всё прошло успешно, а 404
сообщает, что страница не найдена.Очень полезно держать под рукой, когда работаешь с API или отлаживаешь backend.
На картинке показаны самые часто используемые статусы от 100 до 599.
Сохрани, чтобы не забыть!
Please open Telegram to view this post
VIEW IN TELEGRAM
1🔥18❤7👍5
❤13👍10🔥6🤝1
Он ищет минимальные расстояния от одной вершины до всех остальных в графе с неотрицательными весами рёбер.
Ключевые моменты:
• Инициализация расстояний: все бесконечны, кроме стартовой вершины.
• Цикл обработки: достаём вершину с минимальным расстоянием, обновляем её соседей.
• Функция relax обновляет путь к соседу, если найден более выгодный маршрут.
Алгоритм прост в реализации и идеально подходит для задач с положительными весами.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥26❤6👍5🤝3
This media is not supported in your browser
VIEW IN TELEGRAM
На нём собраны лаконичные карточки-паттерны с рабочими примерами кода, указанием минимального стандарта языка и подробным описанием назначения приёма.
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥15👍5❤4
Он берет ресурс «в единоличное владение» и автоматически освобождает его при выходе из области видимости. Код чище, намерения понятнее — никаких manual delete.
Что важно знать:
• RAII-подход: объект уничтожается автоматически, даже при исключениях
• Указатель нельзя копировать, но можно перемещать → один владелец, один delete
• std::make_unique — безопасный способ создания: защищает от утечек при new
unique_ptr прост, компактен и отлично сочетается с современным стилем C++.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
❤15🔥12🤝11👍6😁1
This media is not supported in your browser
VIEW IN TELEGRAM
База реальных собеседований от Т-Банк, Яндекса, Сбера и 100+ топовых компаний. 10 000+ вопросов по Frontend, Backend, DevOps и другим направлениям. Удобный тренажёр, персональная статистика и еженедельные обновления.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤7👍5🔥5🤝2
Быстро тестируем код через assert.
Сейчас научимся добавлять простые проверки прямо в код, чтобы убедиться, что функции работают правильно. Это особенно удобно на этапе отладки и для мини-тестов без фреймворков.
Подключим нужную библиотеку:
Предположим, у нас есть функция, которая должна возвращать квадрат числа. Реализуем её так:
Теперь напишем несколько простых тестов с помощью assert, чтобы проверить, что функция работает правильно на базовых примерах:
Если проверка не пройдёт — программа остановится и покажет, где ошибка.
Вот как может выглядеть ошибка, если ожидание не совпадает с результатом:
🔥 Таким образом ты можешь быстро проверять поведение функций — без сторонних библиотек и с минимальным кодом.
📣 C++ Ready | #практика
Сейчас научимся добавлять простые проверки прямо в код, чтобы убедиться, что функции работают правильно. Это особенно удобно на этапе отладки и для мини-тестов без фреймворков.
Подключим нужную библиотеку:
#include <cassert>
#include <iostream>
Предположим, у нас есть функция, которая должна возвращать квадрат числа. Реализуем её так:
int square(int x) {
return x * x;
}
Теперь напишем несколько простых тестов с помощью assert, чтобы проверить, что функция работает правильно на базовых примерах:
int main() {
assert(square(2) == 4);
assert(square(-3) == 9);
assert(square(0) == 0);
std::cout << "Все тесты пройдены!\n";
return 0;
}
Если проверка не пройдёт — программа остановится и покажет, где ошибка.
Вот как может выглядеть ошибка, если ожидание не совпадает с результатом:
Assertion failed: square(2) == 5, file main.cpp, line 10
🔥 Таким образом ты можешь быстро проверять поведение функций — без сторонних библиотек и с минимальным кодом.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤25👍9🔥8🤝1