C/C++ | LeetCode

channel icon
Сайт: easyoffer.ru

Условия размещения

Цена за 48 часов в ленте 1500,00
Цена за 1 час закрепления N/A
Взаимопиар Нет
Дополнительные условия рекламы Отсутствуют
-3
3 653
подписчиков
-5
522
охват 1 публикации
0
~4
постов / день
-0,1%
14,3%
ERR % ?

Статистика

Последние публикации

C/C++ | LeetCode
22 декабря 2024 г. 12:07
#medium
Задача: 513. Find Bottom Left Tree Value

Дан корень двоичного дерева, верните самое левое значение в последней строке дерева.

Пример:
Input: root = [2,1,3]
Output: 1


👨‍💻 Алгоритм:

1⃣Инициализируйте переменную maxDepth для хранения глубины нижнего уровня дерева. Инициализируйте переменную bottomLeftValue для хранения самого левого значения в последней строке дерева.

2⃣Реализуйте рекурсивную функцию dfs, которая обходит дерево и находит самое левое значение в последней строке дерева. Параметры функции: current (текущий узел) и depth (его глубина). Проверьте, пуст ли текущий узел. Если да, то вернитесь.

3⃣Проверьте, превышает ли текущая глубина глобальную переменную maxDepth. Если да, это значит, что мы нашли новый уровень. Установите maxDepth в значение текущей глубины. Установите bottomLeftValue в значение текущего узла. Рекурсивно вызовите dfs для левого поддерева текущего узла, увеличив глубину на один. Рекурсивно вызовите dfs для правого поддерева текущего узла, увеличив глубину на один. Вызовите dfs с корнем и начальной глубиной 0. Верните bottomLeftValue.

😎 Решение:
class Solution {
int maxDepth = -1;
int bottomLeftValue = 0;

public:
int findBottomLeftValue(TreeNode* root) {
dfs(root, 0);
return bottomLeftValue;
}

void dfs(TreeNode* current, int depth) {
if (!current) return;

if (depth > maxDepth) {
maxDepth = depth;
bottomLeftValue = current->val;
}

dfs(current->left, depth + 1);
dfs(current->right, depth + 1);
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
21 декабря 2024 г. 19:07
#Hard
Задача: 600. Non-negative Integers without Consecutive Ones

Дано положительное целое число n, верните количество чисел в диапазоне [0, n], бинарные представления которых не содержат последовательных единиц.

Пример:
Input: n = 5
Output: 5
Explanation:
Here are the non-negative integers <= 5 with their corresponding binary representations:
0 : 0
1 : 1
2 : 10
3 : 11
4 : 100
5 : 101
Among them, only integer 3 disobeys the rule (two consecutive ones) and the other 5 satisfy the rule.


👨‍💻 Алгоритм:

1⃣Простой метод заключается в переборе всех чисел от 1 до num. Для каждого текущего выбранного числа проверяем все соседние позиции, чтобы выяснить, содержит ли число две последовательные единицы. Если не содержит, увеличиваем количество чисел без последовательных единиц.

2⃣Чтобы проверить, существует ли 1 на позиции x (считая от младшего значащего бита), в текущем числе n, поступаем следующим образом. Сдвигаем двоичную 1 x−1 раз влево, чтобы получить число y, которое имеет 1 только на x-й позиции. Логическое И числа n и y даст результат 1 только если n содержит 1 на позиции x.

3⃣В конце подсчитываем и возвращаем количество чисел в диапазоне [0, n], не содержащих последовательных единиц.

😎 Решение:
class Solution {
public:
int findIntegers(int num) {
int count = 0;
for (int i = 0; i <= num; i++) {
if (check(i)) {
count++;
}
}
return count;
}

bool check(int n) {
int i = 31;
while (i > 0) {
if ((n & (1 << i)) != 0 && (n & (1 << (i - 1))) != 0) {
return false;
}
i--;
}
return true;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
21 декабря 2024 г. 14:11
Просто используйте подписку на Кинопоиск и Музыку за 1₽Просто используйте подписку на Кинопоиск и Музыку за 1₽

Ответьте на 1 вопрос и получите в подарок доступ к Кинопоиску, Музыке и Книгам на 60 дней за 1 рубль.

✨ Сервисы будут доступны не только для Вас, но и для трёх ваших близких

ПопробоватьПопробовать

#реклама 18+
kinopoisk.ru

О рекламодателе
Реклама на Яндексе
C/C++ | LeetCode
21 декабря 2024 г. 12:07
#Easy
Задача: 599. Minimum Index Sum of Two Lists

Даны два массива строк list1 и list2, необходимо найти общие строки с наименьшей суммой индексов.

Общая строка - это строка, которая появляется и в list1, и в list2.

Общая строка с наименьшей суммой индексов - это общая строка, такая, что если она появилась в list1[i] и list2[j], то i + j должно быть минимальным значением среди всех других общих строк.

Верните все общие строки с наименьшей суммой индексов. Верните ответ в любом порядке.

Пример:
Input: list1 = ["Shogun","Tapioca Express","Burger King","KFC"], list2 = ["Piatti","The Grill at Torrey Pines","Hungry Hunter Steakhouse","Shogun"]
Output: ["Shogun"]
Explanation: The only common string is "Shogun".


👨‍💻 Алгоритм:

1⃣Для каждой строки из list1, сравниваем её с каждой строкой из list2, обходя весь список list2. Используем хэш-таблицу map, которая содержит элементы в виде (сумма: список строк). Здесь сумма относится к сумме индексов совпадающих элементов, а список строк соответствует списку совпадающих строк, чья сумма индексов равна этой сумме.

2⃣Во время сравнений, когда находится совпадение строки на i-м индексе из list1 и j-м индексе из list2, создаём запись в map, соответствующую сумме i + j, если такая запись ещё не существует. Если запись с этой суммой уже существует, добавляем текущую строку в список строк, соответствующих сумме i + j.

3⃣В конце обходим ключи в map и находим список строк, соответствующих ключу с минимальной суммой.

😎 Решение:
#include 
#include
#include
#include
using namespace std;

class Solution {
public:
vector findRestaurant(vector& list1, vector& list2) {
unordered_map> map;
for (int i = 0; i < list1.size(); i++) {
for (int j = 0; j < list2.size(); j++) {
if (list1[i] == list2[j]) {
map[i + j].push_back(list1[i]);
}
}
}
int minIndexSum = INT_MAX;
for (auto& [key, val] : map) {
minIndexSum = min(minIndexSum, key);
}
return map[minIndexSum];
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
20 декабря 2024 г. 19:07
#easy
Задача: 594. Longest Harmonious Subsequence

Мы определяем гармоничный массив как массив, в котором разница между его максимальным и минимальным значением составляет ровно 1.

Дан целочисленный массив nums, верните длину его самой длинной гармоничной подпоследовательности среди всех возможных подпоследовательностей.

Подпоследовательность массива - это последовательность, которую можно получить из массива, удалив некоторые или никакие элементы, не изменяя порядок оставшихся элементов.

Пример:
Input: nums = [1,3,2,2,5,2,3,7]
Output: 5
Explanation: The longest harmonious subsequence is [3,2,2,2,3].


👨‍💻 Алгоритм:

1⃣Пройдитесь по массиву, создавая словарь для подсчета частоты каждого элемента.

2⃣На каждой итерации проверьте, существуют ли в словаре элементы, отличающиеся на 1 от текущего, и обновите максимальную длину гармоничной подпоследовательности.

3⃣Верните максимальную длину гармоничной подпоследовательности.

😎 Решение:
#include 
#include
#include

using namespace std;

class Solution {
public:
int findLHS(vector& nums) {
unordered_map count;
int res = 0;

for (int num : nums) {
count[num]++;
if (count.find(num + 1) != count.end()) {
res = max(res, count[num] + count[num + 1]);
}
if (count.find(num - 1) != count.end()) {
res = max(res, count[num] + count[num - 1]);
}
}

return res;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
20 декабря 2024 г. 18:49
Дарим подписку на Яндекс МузыкуДарим подписку на Яндекс Музыку

Ответьте на 1 вопрос и Яндекс Музыка для вас и 3-х ваших близких 60 дней бесплатно.
Кинопоиск и Яндекс Книги тоже в подписке.
Попробуйте сейчас❤️

ПопробоватьПопробовать

#реклама 18+
music.yandex.ru

О рекламодателе
Реклама на Яндексе
C/C++ | LeetCode
20 декабря 2024 г. 12:07
#Easy
Задача: 598. Range Addition II

Вам дана матрица M размером m x n, инициализированная нулями, и массив операций ops, где ops[i] = [ai, bi] означает, что значение M[x][y] должно быть увеличено на единицу для всех 0 <= x < ai и 0 <= y < bi.

Подсчитайте и верните количество максимальных чисел в матрице после выполнения всех операций.

Пример:
Input: m = 3, n = 3, ops = [[2,2],[3,3]]
Output: 4
Explanation: The maximum integer in M is 2, and there are four of it in M. So return 4.


👨‍💻 Алгоритм:

1⃣Все операции выполняются на прямоугольной подматрице изначальной матрицы M, заполненной нулями, с верхним левым углом в точке (0,0) и нижним правым углом для операции [i,j] в точке (i,j).

2⃣Максимальный элемент будет тем, на который выполнены все операции. Максимальные элементы будут находиться в области пересечения прямоугольников, представляющих операции. Для определения этой области нужно найти нижний правый угол пересекающейся области (x,y), который равен (min(op[0]), min(op[1])).

3⃣Количество элементов, находящихся в области пересечения, определяется как произведение координат x и y.

😎 Решение:
class Solution {
public:
int maxCount(int m, int n, vector>& ops) {
int minA = m;
int minB = n;
for (auto& op : ops) {
minA = min(minA, op[0]);
minB = min(minB, op[1]);
}
return minA * minB;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
20 декабря 2024 г. 10:00
Полный экскурс в Реверсивный инжиниринг: запись до 26 декабря!

Дарим 3 месяца подписки на Codeby Games при покупке любого курса до 31 декабря! 

В курсе подробно рассматривается синтаксис Ассемблера, анализ приложений различного уровня сложности, от простейших crackme до полноценных программ на современных архитектурах.
Необходимые знания: язык Ассемблера, С/С++, python, навыки работы с IDA и другими инструментами для реверса

Вы получите сертификат/удостоверение о повышении квалификации

Пишите нам @Codeby_Academy@Codeby_Academy или оставьте заявку на сайтезаявку на сайтезаявку на сайте
C/C++ | LeetCode
19 декабря 2024 г. 19:07
#medium
Задача: 593. Valid Square

Даны координаты четырех точек в 2D-пространстве p1, p2, p3 и p4. Верните true, если эти четыре точки образуют квадрат.

Координата точки pi представлена как [xi, yi]. Ввод не дан в каком-либо определенном порядке.

Корректный квадрат имеет четыре равные стороны с положительной длиной и четыре равных угла (по 90 градусов).

Пример:
Input: p1 = [0,0], p2 = [1,1], p3 = [1,0], p4 = [0,1]
Output: true


👨‍💻 Алгоритм:

1⃣Определите функцию для вычисления расстояния между двумя точками.

2⃣Проверьте, равны ли все стороны и диагонали для трех уникальных случаев перестановки точек.

3⃣Верните true, если хотя бы одна из проверок проходит.

😎 Решение:
#include 
#include

using namespace std;

class Solution {
public:
int dist(vector& p1, vector& p2) {
return pow(p2[1] - p1[1], 2) + pow(p2[0] - p1[0], 2);
}

bool check(vector& p1, vector& p2, vector& p3, vector& p4) {
return dist(p1, p2) > 0 &&
dist(p1, p2) == dist(p2, p3) &&
dist(p2, p3) == dist(p3, p4) &&
dist(p3, p4) == dist(p4, p1) &&
dist(p1, p3) == dist(p2, p4);
}

bool validSquare(vector& p1, vector& p2, vector& p3, vector& p4) {
return check(p1, p2, p3, p4) ||
check(p1, p3, p2, p4) ||
check(p1, p2, p4, p3);
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
19 декабря 2024 г. 17:19
Квартиры в Тюмени в семейную ипотеку от 13 233 ₽/месКвартиры в Тюмени в семейную ипотеку от 13 233 ₽/мес

«Окинава» — современный ЖК в районе озера Алебашево. 10 минут до центра Тюмени.

Не упустите свою выгоду:
✅ Квартиры от 13 233 ₽/мес
✅ Платеж на весь срок
✅ Паркинг в подарок

Это не просто жилой комплекс, это остров 4 стихий. Каждая из стихий — отдельный дом и очередь строительства.

В «Окинаве» есть все для комфортной жизни:
— Видовые квартиры с террасой
— Закрытые дворы-стилобаты
— Функциональные планировки
— 2-уровневый пешеходный бульвар

Зафиксируйте условия покупки и получите подборку планировок! 🏠

Получить предложениеПолучить предложение

Проектная декларация на сайте https://наш.дом.рф/https://наш.дом.рф/. Застройщик: СЗ ИСБ-НЕДВИЖИМОСТЬ. Финансовые услуги оказывает: ПАО "Сбербанк".

#реклама
mrqz.me

О рекламодателе
C/C++ | LeetCode
19 декабря 2024 г. 12:07
#medium
Задача: 592. Fraction Addition and Subtraction

Дана строка, представляющая выражение сложения и вычитания дробей, верните результат вычисления в строковом формате.

Окончательный результат должен быть несократимой дробью. Если ваш окончательный результат является целым числом, преобразуйте его в формат дроби с знаменателем 1. Таким образом, 2 должно быть преобразовано в 2/1.

Пример:
Input: expression = "-1/2+1/2+1/3"
Output: "1/3"


👨‍💻 Алгоритм:

1⃣Начните сканирование строки и разделите её на части, содержащие числители и знаменатели, с учетом знаков.

2⃣Выполните операции сложения или вычитания для каждой пары дробей, приводя их к общему знаменателю и сокращая результат.

3⃣Верните результат в виде строки, представляющей несократимую дробь.

😎 Решение:
#include 
#include
#include
#include
#include

using namespace std;

class Solution {
public:
string fractionAddition(string expression) {
vector sign;
if (expression[0] != '-') sign.push_back('+');
for (char ch : expression) {
if (ch == '+' || ch == '-') sign.push_back(ch);
}

int prev_num = 0, prev_den = 1, i = 0;
stringstream ss(expression);
string sub;

while (getline(ss, sub, '+') || getline(ss, sub, '-')) {
if (sub.empty()) continue;
int num, den;
sscanf(sub.c_str(), "%d/%d", &num, &den);
int g = abs(gcd(prev_den, den));
if (sign[i++] == '+') prev_num = prev_num * den / g + num * prev_den / g;
else prev_num = prev_num * den / g - num * prev_den / g;
prev_den = prev_den * den / g;
g = abs(gcd(prev_den, prev_num));
prev_num /= g;
prev_den /= g;
}

return to_string(prev_num) + "/" + to_string(prev_den);
}

private:
int gcd(int a, int b) {
while (b != 0) {
int t = b;
b = a % b;
a = t;
}
return a;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
18 декабря 2024 г. 19:07
#easy
Задача: 590. N-ary Tree Postorder Traversal

Дано корневое дерево с n-арной структурой, верните обход дерева в постфиксном порядке для значений его узлов.

Сериализация входных данных n-арного дерева представлена в обходе уровней. Каждая группа детей разделяется значением null (см. примеры).

Пример:
Input: root = [1,null,2,3,4,5,null,null,6,7,null,8,null,9,10,null,null,11,null,12,null,13,null,null,14]
Output: [2,6,14,11,7,3,12,8,4,13,9,10,5,1]


👨‍💻 Алгоритм:

1⃣Инициализируйте стек для хранения узлов и список для хранения значений узлов в обратном порядке.

2⃣Начните с корневого узла и добавьте его в стек. Пока стек не пуст, извлекайте узлы из стека, добавляя их значения в начало списка, и добавляйте всех его детей в стек.

3⃣В конце верните список значений узлов.

😎 Решение:
#include 
#include
#include

using namespace std;

class Node {
public:
int val;
vector children;

Node() {}

Node(int _val) {
val = _val;
}

Node(int _val, vector _children) {
val = _val;
children = _children;
}
};

class Solution {
public:
vector postorder(Node* root) {
if (root == nullptr) return {};
stack stk;
vector output;
stk.push(root);

while (!stk.empty()) {
Node* node = stk.top();
stk.pop();
output.push_back(node->val);
for (Node* child : node->children) {
if (child != nullptr) {
stk.push(child);
}
}
}

reverse(output.begin(), output.end());
return output;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
18 декабря 2024 г. 15:49
Миграция в облако? Это легко!Миграция в облако? Это легко!

Собственная инфраструктура устарела или не справляется с нагрузками? Используйте облачные ресурсы! Эксперты Yandex Cloud помогут перейти в облако быстро, легко и безопасно.

✅ Мы полностью сопровождаем процесс.
✅ От вас — только инженер с доступом к инфраструктуре.
✅ Архитектура под ваши задачи, миграция и поддержка на каждом шагу — всё включено.

⚡Переходите в Yandex Cloud и забудьте о старом железе. А если успеете подать заявку до 31 декабря, мы покроем расходы на инженеров и тестовую инфраструктуру.

Подать заявкуПодать заявку

#реклама 16+
yandex.cloud

О рекламодателе
Реклама на Яндексе
C/C++ | LeetCode
18 декабря 2024 г. 12:07
#easy
Задача: 557. Reverse Words in a String III

Дана строка s. Необходимо изменить порядок символов в каждом слове в предложении, сохранив при этом пробелы и начальный порядок слов.

Пример:
Input: s = "Let's take LeetCode contest"
Output: "s'teL ekat edoCteeL tsetnoc"


👨‍💻 Алгоритм:

1⃣Создайте переменную lastSpaceIndex и установите её значение в -1. Пройдите по каждому символу строки s от 0-го до n-го индекса, используя указатель strIndex.

2⃣Когда strIndex указывает на пробел, определите начало (startIndex = lastSpaceIndex + 1) и конец (endIndex = strIndex - 1) текущего слова. Используя два указателя, измените порядок символов в текущем слове.

3⃣Обновите lastSpaceIndex значением strIndex. После окончания цикла измените порядок символов в последнем слове (от lastSpaceIndex + 1 до конца строки).

😎 Решение:
#include 
using namespace std;

class Solution {
public:
string reverseWords(string s) {
int lastSpaceIndex = -1;
int len = s.size();

for (int strIndex = 0; strIndex <= len; strIndex++) {
if (strIndex == len || s[strIndex] == ' ') {
int startIndex = lastSpaceIndex + 1;
int endIndex = strIndex - 1;
while (startIndex < endIndex) {
char temp = s[startIndex];
s[startIndex] = s[endIndex];
s[endIndex] = temp;
startIndex++;
endIndex--;
}
lastSpaceIndex = strIndex;
}
}

return s;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
18 декабря 2024 г. 10:00
А вы знали что?...

🕵️В Windows есть папка, которая собирает на вас компромат!

Посмотрите видео выше — насколько легко узнать всю информацию о вас

Простых способов узнать о вас практически всё — сотни, и если вы хотите соблюдать хотя бы минимум сетевой гигиены — подпишитесь на IT ВЕДОМСТВО

Они рассказывает о признаках майнеров, как удалить трояны и порно-баннеры за 5 минут

Помимо всего этого, сейчас владелец канала проводит розыгрыш умной колонки, для всех новоприбывших подписчиков

💻 Подписываемся на IT ВЕДОМСТВОIT ВЕДОМСТВО — выигрываем призы и соблюдаем цифровую гигиену
C/C++ | LeetCode
17 декабря 2024 г. 19:07
#medium
Задача: 556. Next Greater Element III

Мы можем перемешать строку s, чтобы получить строку t, используя следующий алгоритм:

Дано положительное целое число n. Найдите наименьшее целое число, которое имеет точно такие же цифры, как и число n, и больше самого числа n по значению. Если такого положительного целого числа не существует, верните -1.

Учтите, что возвращенное число должно помещаться в 32-битное целое число. Если существует допустимый ответ, но он не помещается в 32-битное целое число, верните -1.

Пример:
Input: n = 12
Output: 21


👨‍💻 Алгоритм:

1⃣Нахождение и перестановка цифр
Преобразуйте число n в массив цифр. Найдите первую цифру, которая нарушает убывающий порядок (с конца массива). Назовем её индексом i. Найдите первую цифру, которая больше digits[i-1] (с конца массива). Назовем её индексом j. Поменяйте местами цифры на позициях i-1 и j.

2⃣Обратный порядок оставшихся цифр
Обратный порядок части массива от индекса i до конца, чтобы получить наименьшую перестановку, которая больше исходной.

3⃣Проверка результата и преобразование обратно в число
Преобразуйте массив цифр обратно в число. Если число превышает 32-битный предел, верните -1. В противном случае верните полученное число.

😎 Решение:
#include 
#include
#include

class Solution {
public:
std::string swap(const std::string& s, int i0, int i1) {
if (i0 == i1) return s;
std::string result = s;
std::swap(result[i0], result[i1]);
return result;
}

std::vector list;

void permute(std::string a, int l, int r) {
if (l == r) {
list.push_back(a);
} else {
for (int i = l; i <= r; i++) {
a = swap(a, l, i);
permute(a, l + 1, r);
a = swap(a, l, i);
}
}
}

int nextGreaterElement(int n) {
std::string s = std::to_string(n);
permute(s, 0, s.size() - 1);
std::sort(list.begin(), list.end());
auto it = std::find(list.begin(), list.end(), s);
if (it != list.end() && it + 1 != list.end()) {
long result = std::stol(*(it + 1));
if (result <= INT_MAX) return result;
}
return -1;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
17 декабря 2024 г. 17:05
Жилой район "Патрики" в Краснодаре!Жилой район "Патрики" в Краснодаре!

Квартиры бизнес-класса в новом районе города.

Патрики - это умный район. Въезд на территорию — по автоматическому определению номера, вход — с помощью системы распознавания лиц. В квартире вы управляете — температурой и электроприборами.

- 3 детских сада на 760 мест
- инновационная школа на 1 550 мест
- 4 000 парковочных мест
- 5 аллей и бульваров
- модные рестораны и бутики

Спецпредложение: рассрочка до конца строительства с первоначальным взносом от 10%. Успейте купить

Получить предложениеПолучить предложение

#реклама
promo.tochno-patriki.ru

О рекламодателе
C/C++ | LeetCode
17 декабря 2024 г. 12:07
#medium
Задача: 554. Brick Wall

Перед вами находится прямоугольная кирпичная стена с n рядами кирпичей. В i-м ряду находится несколько кирпичей одинаковой высоты (то есть один юнит), но они могут быть разной ширины. Общая ширина каждого ряда одинакова.

Нарисуйте вертикальную линию от верха до низа, пересекающую наименьшее количество кирпичей. Если ваша линия проходит по краю кирпича, то кирпич не считается пересеченным. Вы не можете нарисовать линию прямо по одному из двух вертикальных краев стены, так как в этом случае линия очевидно не пересечет ни одного кирпича.

Дан двумерный массив wall, содержащий информацию о стене, верните минимальное количество пересеченных кирпичей после проведения такой вертикальной линии.

Пример:
Input: wall = [[1,2,2,1],[3,1,2],[1,3,2],[2,4],[3,1,2],[1,3,1,1]]
Output: 2


👨‍💻 Алгоритм:

1⃣Определите общую ширину стены, сложив ширины кирпичей в первом ряду. Создайте массив pos, где pos[i] указывает на текущую позицию в i-ом ряду.

2⃣Пройдите по каждой возможной позиции для вертикальной линии (от 1 до общей ширины стены - 1). Для каждой позиции обновите массив pos, проверяя, пересекает ли линия границу кирпича. Если пересекает, увеличьте значение pos[i].

3⃣Подсчитайте количество кирпичей, которые пересечет вертикальная линия для каждой возможной позиции, обновляя счетчик. Выберите минимальное количество пересеченных кирпичей из всех возможных позиций для вертикальной линии.

😎 Решение:
class Solution {
public:
int leastBricks(vector>& wall) {
vector pos(wall.size(), 0);
int sum = 0, res = INT_MAX;

for (int el : wall[0])
sum += el;

while (sum != 0) {
int count = 0;
for (int i = 0; i < wall.size(); i++) {
if (wall[i][pos[i]] != 0)
count++;
else
pos[i]++;
wall[i][pos[i]]--;
}
sum--;
res = min(res, count);
}

return res;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
16 декабря 2024 г. 19:07
#hard
Задача: 420. Strong Password Checker

Пароль считается надежным, если выполняются следующие условия: в нем не менее 6 и не более 20 символов. он содержит не менее одной строчной буквы, не менее одной заглавной буквы и не менее одной цифры. он не содержит трех повторяющихся символов подряд (например, "Baaabb0" - слабый, а "Baaba0" - сильный). Учитывая строку пароля, верните минимальное количество шагов, необходимых для того, чтобы сделать пароль сильным. Если пароль уже сильный, верните 0. За один шаг можно: вставить один символ в пароль, удалить один символ из пароля или заменить один символ пароля другим символом.

Пример:
Input: password = "a"
Output: 5


👨‍💻 Алгоритм:

1⃣Определите количество недостающих символов до минимума и превышающих символов для ограничения длины пароля. Также определите наличие строчных, заглавных букв и цифр.

2⃣Вычислите количество необходимых замен для устранения трех повторяющихся символов подряд.

3⃣Определите минимальное количество шагов для приведения пароля к требуемым условиям, используя вычисленные значения недостающих символов, превышающих символов и замен.

😎 Решение:
using namespace std;

class Solution {
public:
int strongPasswordChecker(string s) {
int n = s.length();
bool hasLower = false, hasUpper = false, hasDigit = false;
int repeatCount = 0;

for (int i = 0; i < n;) {
if (islower(s[i])) hasLower = true;
if (isupper(s[i])) hasUpper = true;
if (isdigit(s[i])) hasDigit = true;

int start = i;
while (i < n && s[i] == s[start]) {
i++;
}
repeatCount += (i - start) / 3;
}

int missingTypes = (hasLower ? 0 : 1) + (hasUpper ? 0 : 1) + (hasDigit ? 0 : 1);

if (n < 6) {
return max(missingTypes, 6 - n);
} else if (n <= 20) {
return max(missingTypes, repeatCount);
} else {
int excessChars = n - 20;
int overLenReduction = 0;
for (int i = 2; i < n && excessChars > 0; i++) {
if (i % 3 == 2 && s[i] == s[i - 1] && s[i] == s[i - 2]) {
overLenReduction++;
excessChars--;
}
}
repeatCount -= overLenReduction;
return (n - 20) + max(missingTypes, repeatCount);
}
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний
C/C++ | LeetCode
16 декабря 2024 г. 12:07
#medium
Задача: 553. Optimal Division

Дано целочисленный массив nums. Соседние целые числа в nums будут выполнять деление с плавающей запятой.

Например, для nums = [2,3,4] мы будем вычислять выражение "2/3/4".
Однако, вы можете добавить любое количество скобок в любое место, чтобы изменить приоритет операций. Вы хотите добавить эти скобки так, чтобы значение выражения после вычисления было максимальным.

Верните соответствующее выражение, которое имеет максимальное значение в строковом формате.

Пример:
Input: nums = [1000,100,10,2]
Output: "1000/(100/10/2)"
Explanation: 1000/(100/10/2) = 1000/((100/10)/2) = 200
However, the bold parenthesis in "1000/((100/10)/2)" are redundant since they do not influence the operation priority.
So you should return "1000/(100/10/2)".
Other cases:
1000/(100/10)/2 = 50
1000/(100/(10/2)) = 50
1000/100/10/2 = 0.5
1000/100/(10/2) = 2


👨‍💻 Алгоритм:

1⃣Разверните оба числа. Инициализируйте массив ans с (N+M) нулями. Для каждой цифры во втором числе: держите переменную переноса, изначально равную 0. Инициализируйте массив (currentResult), начинающийся с некоторых нулей в зависимости от места цифры во втором числе.

2⃣Для каждой цифры первого числа: умножьте цифру второго числа на цифру первого числа и добавьте предыдущий перенос к результату умножения. Возьмите остаток от деления на 10, чтобы получить последнюю цифру. Добавьте последнюю цифру к массиву currentResult. Разделите результат умножения на 10, чтобы получить новое значение переноса.

3⃣После итерации по каждой цифре в первом числе, если перенос не равен нулю, добавьте перенос к массиву currentResult. Добавьте currentResult к массиву ans. Если последняя цифра в ans равна нулю, перед разворотом ans удалите этот ноль, чтобы избежать ведущего нуля в окончательном ответе. Разверните ans и верните его.

😎 Решение:
class Solution {
private:
vector addStrings(vector num1, vector& num2) {
vector ans;
int carry = 0;

for (int i = 0; i < num1.size() || i < num2.size() || carry; ++i) {
int digit1 = i < num1.size() ? num1[i] : 0;
int digit2 = i < num2.size() ? num2[i] : 0;
int sum = digit1 + digit2 + carry;
carry = sum / 10;
ans.push_back(sum % 10);
}

return ans;
}

vector multiplyOneDigit(string& firstNumber, char& secondNumberDigit, int numZeros) {
vector currentResult(numZeros, 0);
int carry = 0;

for (char firstNumberDigit : firstNumber) {
int multiplication = (secondNumberDigit - '0') * (firstNumberDigit - '0') + carry;
carry = multiplication / 10;
currentResult.push_back(multiplication % 10);
}

if (carry) {
currentResult.push_back(carry);
}
return currentResult;
}

public:
string multiply(string firstNumber, string secondNumber) {
if (firstNumber == "0" || secondNumber == "0") {
return "0";
}

reverse(firstNumber.begin(), firstNumber.end());
reverse(secondNumber.begin(), secondNumber.end());

vector ans(firstNumber.size() + secondNumber.size(), 0);

for (int i = 0; i < secondNumber.size(); ++i) {
ans = addStrings(multiplyOneDigit(firstNumber, secondNumber[i], i), ans);
}

while (ans.back() == 0) {
ans.pop_back();
}

string answer;
for (int i = ans.size() - 1; i >= 0; --i) {
answer.push_back(ans[i] + '0');
}

return answer;
}
};


Ставь 👍👍 и забирай 📚 📚 Базу знанийБазу знаний