Так-С, друзья, есть таков вопрос: fn insertion_sort(mut arr: Vec<i32>) -> Vec<i32>

{
let arr_len: usize = arr.len();

for i in 1..arr_len {
let mut j = i;
while j > 0 && arr[j] < arr[j - 1] {
(arr[j], arr[j - 1]) = (arr[j - 1], arr[j]);
j -= 1;
}
}

arr
}

Видим сортировку вставками. Как ее реализовать чисто на итераторах, без for, while и т.п.?
Для примера реализации чисто на итераторах (может не лучшей) уже пузырьковой сортировки:
fn bubble_sort(mut arr: Vec<i32>) -> Vec<i32> {
(0..arr.len()) // создаем индексы как диапазон чисел от 0 до длины вектора
.into_iter() // преобразуем полный диапазон в итератор
.for_each(|i| { // итерируемся по каждому индексу из полного диапазона вектора
(0..(arr.len() - i - 1)) // создаем диапазон чисел (длина вектора - номер итерации - 1), чтобы не проверять последнюю и уже пройденные, ибо они уже отсортированы
.into_iter() // преобразуем малый диапазон в итератор
.for_each(|j| { // итерируемся по каждому индексу из малого диапазона вектора
if arr[j] > arr[j + 1] { // сравниваем пару чисел по указателям в соответствии с условием
(arr[j], arr[j + 1]) = (arr[j + 1], arr[j]); // если совпадает по условию - меняем местами (сортирование)
}
})
});

arr // возвращаем отсортированный вектор
}

3 ответов

24 просмотра

Ну можно j через итератор + windows() найти, а потом сказать то ли rotate_left,то ли rotate_right

Владимир Латыпов
Но это будет не «чисто на итераторах»…

ну да, но по-моему это странное желание уже

Похожие вопросы

Обсуждают сегодня

Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
7
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Есть тут кто занимается разработкой серваков майна? Или знакомые
meow *
3
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Есть ли лимиты на кол-во вебхук по домену? Стоит в данный момент 900+ ботов и бывает бот перестает отвечать (не приходят вебхуки) 🐒 Помогает только перезапуск
ᅠ [ Кому не ответил, дублируйте ]
11
а что делать если тебя убивают на картах?
Yarik yarik kyda ti lezesh
43
Товарищи, здравствуйте Подскажите, пожалуйста, может кто-нибудь сталкивался с такой задачей Через вебапку можно сканировать qr-код, а есть ли возможность считывать nfc?
Artem Stormageddon
8
Карта сайта