Так должно быть поэффективней чутка let x

= "dir a\n14848514 b.txt\n8504156 c.dat\ndir d";
let mut nums = vec!();

let mut start = 0usize;
let mut in_num = false;

for (i, c) in x.chars().enumerate() {
if c.is_ascii_digit() {
if !in_num {
in_num = true;
start = i;
}
} else {
if in_num {
nums.push(&x[start..i]);
in_num = false;
}
}
}


println!("{:?}", nums);


но эт нужно смотреть в годболте и бенчмарками

9 ответов

28 просмотров

Можно же просто сплитнуть по нецифрам и потом пофильтровать, чтоб непустые строки были (если в расширениях цифр не будет)

Alexey-Ermakov Автор вопроса
Traveller Kolsky
Можно же просто сплитнуть по нецифрам и потом пофи...

сплит это 1 итерация фильтр еще одна потом ещё собрать это

Alexey-Ermakov Автор вопроса

кинь код, попробую в бенч закинуть

Alexey Ermakov
кинь код, попробую в бенч закинуть

str.split(|c: char| !c.is_ascii_digit()).filter(|s| !s.is_empty()) Вроде

Alexey-Ermakov Автор вопроса
Traveller Kolsky
str.split(|c: char| !c.is_ascii_digit()).filter(|s...

test tests::bench_f1 ... bench: 85 ns/iter (+/- 2) test tests::bench_f2 ... bench: 58 ns/iter (+/- 4) f1 твой вариант, f2 мой

Кстати оно сфейлит ещё, если будет просто число в конце, после итерации нужно проверить, что in_num задан

Alexey-Ermakov Автор вопроса
Traveller Kolsky
Кстати оно сфейлит ещё, если будет просто число в ...

Там и с utf8 будут проблемы. Я саму идею передать. А так там нужно не chars, а bytes и проверки корнер кейсов

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

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

if (user?.choseType === 'oneDay') { await ctx.reply( 'Добро пожаловать в команду «Магнита»! Правда, на один день ☺️ ', ); await ctx.s...
Kokni
1
всем салют сегодня утро заметил что бот не может отправлять фотки по url. ручками в браузере ссылка норм открывает фотки. падает ошибка 'Bad Request: failed to send message ...
Vasya Ivanov
9
https://pastebin.com/BC4pjp4u кто-нибудь мне может объяснить почему это так работает и как работает правильно wizard и почему иногда в контекст появляются сообщения от бота, н...
Kokni
1
Сonst magicTgHTML = (text, entities) => { let processedText = text; let offsetShift = 0; entities.forEach(entity => { const { offset, length, type, url, ...
Андрей
1
а что делать если тебя убивают на картах?
Yarik yarik kyda ti lezesh
43
Мне вот что интересно, кто на рфе стартовал/играл, что вы фармили, в каком виде контента он прямо хорош? Экспедиция? Вроде прямо на замазанных мапах рф сдувается
Владислав
20
‌/r/pathofexile moderation changes top scoring links : pathofexile (RSS) Hi, everyone. On behalf of the subreddit mod team, I’m here to give you a few updates on the subreddi...
Esionru
3
Подскажите где можно прочитать про реализацию возможности писать человеку при подписке на телеграм канал от имени бота? Было бы не плохо если для Telegraf@3.38.0
Pan Lipton
10
У меня вопрос к знающими, стоит ли вступать в гильдии в игре или лучше полная свобода?
Енот Полоскун
17
У вас бывает ощущение, что хочется потратить весь отпуск на то, чтоб только спать?
Николай
15
Карта сайта