amarao: (Default)
[personal profile] amarao
Задача: конвертация из числа в roman numerals:

impl Solution {
fn next_biggest(num: i32) -> (&'static [u8], i32) {
match num {
1000.. => (b"M", 1000),
900.. => (b"CM", 900),
500.. => (b"D", 500),
400.. => (b"CD", 400),
100.. => (b"C", 100),
90.. => (b"XC", 90),
50.. => (b"L", 50),
40.. => (b"XL", 40),
10.. => (b"X", 10),
9.. => (b"IX", 9),
5.. => (b"V", 5),
4.. => (b"IV", 4),
1.. => (b"I", 1),
_ => unimplemented!("Unable to represent in Roman")
}
}
pub fn int_to_roman(mut num: i32) -> String {
let mut acc = Vec::new();
while num > 0{
let (rom, value) = Self::next_biggest(num);
acc.extend_from_slice(rom);
num -= value;
}
String::from_utf8(acc).unwrap()
}
}

Ключевое know-how: Возвращать reference'ы на &'static [u8], который на самом деле кусок будущей строки и использовать "байтовые строки" для констант (b"str_content").

Не то, чтобы это был Trait Science, но любые другие выкрутасы с String или Vec<char> были бы куда более уродливыми или неэффективными. А тут я беру и возвращаю указатели на статические строки (которые и так и так у меня в .data будут), и из них мирно собираю строку. Точнее, я собираю в [u8], которую потом копирую в String.

Возможно, вместо while можно было бы иметь итератор, но я не уверен в выполнимости этого.
Ещё одно место "думать" - в районе extend_from_slice, т.к. я могу вызывать несколько реаллоакций в процессе 'extend', а мне по-хорошему надо было бы знать длину строки с самого начала. Но это отдельная интересная задача - определить размер строки для roman numeral по числовому значению.

Date: 2022-10-20 06:30 pm (UTC)
sab123: (Default)
From: [personal profile] sab123
Про Раст. Очень корявый синтаксис. Ну, менее корявый, чем в Питоне, но это небольшое достижение, хуже чем в Питоне сделать практически невозможно. Ну и того, в Питоне то же самое с тем же успехом делается через if-else.

Про конкретно решение - лишняя функция представляется тут ненужной, код лучше смотрелся бы внутри цикла.

Date: 2022-10-26 04:21 am (UTC)
sab123: (Default)
From: [personal profile] sab123
Мне представляется, что специальные узкие синтаксисы на каждый случай бесполезны, их замучаешься запоминать, один геморрой. Точно так же, как бесполезны и вредны "алгоритмы" из STL, которые сводятся к циклам - проще и понятнее написать руками цикл.

Название не заменяет комментарии, а только создает иллюзию этого. Еще хуже, если оно приводит к очень длинным названиям, которые ни туда ни сюда - и замучаешься запоминать и отличать, и объяснять ничего не объясняет. Но главная моя претензия - в том, что вынос кода в одноразовую функцию нарушает последовательность чтения. При чтении кода приходится прыгать к определению функции и потом назад. И это еще хорошо, если читать в vi, в котором можно поставить метку и и потом прыгнуть назад к ней. А в тех редакторах, где нет меток - еще хуже.

Date: 2022-10-29 04:45 am (UTC)
sab123: (Default)
From: [personal profile] sab123
Я не уверен, что это полезный тип. Точно так же, как питоновский range меня очень раздражает.

> Если имена не важны, то и имена переменных тоже не важны. c(i(j), k[l][m(n)]) и всё такое.

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

Profile

amarao: (Default)
amarao

February 2026

S M T W T F S
123456 7
8910111213 14
15161718192021
22232425262728

Most Popular Tags

Page Summary

Style Credit

Expand Cut Tags

No cut tags
Page generated Feb. 25th, 2026 06:44 pm
Powered by Dreamwidth Studios