Algo1C: Решение алгоритмических задач на базе 1С:Предприятие [Часть #10]

27.09.24

Разработка - Математика и алгоритмы

Решаем новые задачи из LeetCode и CodeWars!

Йо, меня зовут Наби. Заранее благодарю за чтение и желаю продуктивно провести время! Если после прочтения возникнут вопросы, пожелания или предложения, то буду рад ознакомиться со всем в комментариях!


Предисловие:

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

Перед началом чтения решения задачи, хочу призвать каждого к самостоятельному решению задачи, чтобы после вы могли сравнить своё решение с моим и обсудить это в комментариях. Буду рад послушать ваше мнение! Давайте, приступим!


Новое в конфигурации Algo1C (Последние 5 версий):

Актуальную версию конфигурации вы можете загрузить здесь (Нажмите на строку)

- 0.5 : Добавлена возможность выбирать контекст исполнения кода, например: НаСервере или НаКлиенте

- 0.4 : Исправлена ошибка при выводе содержимого исключения

- 0.3 : Добавлена возможность сохранять и загружать задачи; Внесены небольшие изменения в интерфейс

- 0.2 : Исправлена ошибка при выводе результата (Отдельная благодарность SAShikutkin)

 


Решение задач:

 
 Задача 1

 Платформа: CodeWars

 Название задачи: Disemvowel Trolls (Потрошите троллей)

 Ссылка на задачу: https://www.codewars.com/kata/52fba66badcd10859f00097e (Нажмите на строку)

 Сложность: 7 kyu

 Тэги: Строки, Регулярные выражения, Фундаментальные

 Оригинальное описание задачи:

Trolls are attacking your comment section!

A common way to deal with this situation is to remove all of the vowels from the trolls' comments, neutralizing the threat.

Your task is to write a function that takes a string and return a new string with all vowels removed.

For example, the string "This website is for losers LOL!" would become "Ths wbst s fr lsrs LL!".

Note: for this kata y isn't considered a vowel.

Пояснение:

По условию задачи нам необходимо нейтрализовать все угрозы троллей, удалив все гласные буквы английского языка из них. В английском, в зависимости от ситуации и контекста, буква "Y" может трактоваться как гласная. Конкретно в нашем случае автор уточняет что можем не брать её во внимание. Давайте приступим!


Решение:

Для начала определим массив со всеми гласными английского языка, от которых мы хотим избавиться. Далее создадим цикл и пройдёмся по всем элементам этого массива. В каждой итерации цикла будем удалять текущий символ в обоих регистрах из исходной строки. Вот как это будет выглядеть в коде:

ИсходнаяСтрока = "This website is for losers LOL!";
//
Гласные = Новый Массив;
Гласные.Добавить("a");
Гласные.Добавить("e");
Гласные.Добавить("i");
Гласные.Добавить("o");
Гласные.Добавить("u");
//
Для Каждого Стр Из Гласные Цикл
	ИсходнаяСтрока = СтрЗаменить(ИсходнаяСтрока,Стр,"");
	ИсходнаяСтрока = СтрЗаменить(ИсходнаяСтрока,ВРег(Стр),"");	
КонецЦикла;
//
Вывод = ИсходнаяСтрока;

Заключение:

Хоть и суть задачи была весьма простой, лор задачи с Троллями был весьма забавным. Такие задачи всегда занимательно решать!

 
 Задача 2
 
 Задача 3
 
 Задача 4
 
 Задача 5
 
 Задача 6

Заключение:

Ну что ж, пока на этом всё, надеюсь статья была увлекательной для вас, благодарю за внимание. Подключайтесь к решению алгоритмических задач вместе со мной, делитесь вашим мнением и решениями в комментариях! Увидимся в новой статье!

Алгоритмы Математика Оптимизация кода LeetCode CodeWats

См. также

Математика и алгоритмы Программист Платформа 1C v8.2 Конфигурации 1cv8 Россия Абонемент ($m)

На написание данной работы меня вдохновила работа @glassman «Переход на ClickHouse для анализа метрик». Автор анализирует большой объем данных, много миллионов строк, и убедительно доказывает, что ClickHouse справляется лучше PostgreSQL. Я же покажу как можно сократить объем данных в 49.9 раз при этом: 1. Сохранить значения локальных экстремумов 2. Отклонения от реальных значений имеют наперед заданную допустимую погрешность.

1 стартмани

30.01.2024    2742    stopa85    12    

36

Математика и алгоритмы Бесплатно (free)

Разработка алгоритма, построенного на модели симплекс-метода, для нахождения оптимального раскроя.

19.10.2023    6663    user1959478    50    

36

Математика и алгоритмы Разное Платформа 1С v8.3 Конфигурации 1cv8 Россия Абонемент ($m)

Расширение (+ обработка) представляют собою математический тренажер. Ваш ребенок сможет проверить свои знание на математические вычисление до 100.

2 стартмани

29.09.2023    2675    maksa2005    8    

25

Математика и алгоритмы Инструментарий разработчика Программист Платформа 1С v8.3 Мобильная платформа Россия Абонемент ($m)

Что ж... лучше поздно, чем никогда. Подсистема 1С для работы с регулярными выражениями: разбор выражения, проверка на соответствие шаблону, поиск вхождений в тексте.

1 стартмани

09.06.2023    10211    7    SpaceOfMyHead    18    

61

Математика и алгоритмы Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Три задачи - три идеи - три решения. Мало кода, много смысла. Мини-статья.

03.04.2023    3946    RustIG    9    

25

Механизмы платформы 1С Математика и алгоритмы Программист Платформа 1С v8.3 Россия Бесплатно (free)

В статье анализируются средства платформы для решения системы линейных уравнений в 1С. Приводятся доводы в пользу некорректной работы встроенных алгоритмов, а значит потенциально некорректного расчета себестоимости в типовых конфигурациях.

23.11.2022    3061    gzharkoj    14    

24

Математика и алгоритмы Программист Платформа 1С v8.3 Россия Абонемент ($m)

Обычно под распределением понимают определение сумм пропорционально коэффициентам. Предлагаю включить сюда также распределение по порядку (FIFO, LIFO) и повысить уровень размерности до 2-х. 1-ое означает, что распределение может быть не только пропорциональным, но и по порядку, а 2-ое - это вариант реализации матричного распределения: по строкам и столбцам. Возможно вас заинтересует также необычное решение этой задачи через создание DSL на базе реализации текучего интерфейса

1 стартмани

21.03.2022    8881    7    kalyaka    11    

44
Оставьте свое сообщение