Как перевести из арабских цифр в римские? Я смотрел чужие исходники и все такое, но не понял способ. Объясните пожалуйста.
№ | Пользователь | Рейтинг |
---|---|---|
1 | jiangly | 3976 |
2 | tourist | 3815 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3614 |
5 | orzdevinwang | 3526 |
6 | ecnerwala | 3514 |
7 | Benq | 3482 |
8 | hos.lyric | 3382 |
9 | gamegame | 3374 |
10 | heuristica | 3357 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 169 |
2 | -is-this-fft- | 165 |
3 | Um_nik | 161 |
3 | atcoder_official | 161 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 154 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
Название |
---|
string to_roman(int x)
{
string I[] = { "", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX" };
string X[] = { "", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC" };
string C[] = { "", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM" };
string M[] = { "", "M", "MM", "MMM" };
string re;
re = I[x%10] + re;
x/=10;
re = X[x%10] + re;
x/=10;
re = C[x%10] + re;
x/=10;
re = M[x%10] + re;
return re;
}
string toR( int n )
{
string s = "";
int q;
char v[4][4][3] = {
{ "I", "V", "IX", "IV" },
{ "X", "L", "XC", "XL" },
{ "C", "D", "CM", "CD" },
{ "M", "", "", "" },
};
loop(t,0,4)
{
q = n % 10;
n /= 10;
if( q == 9 )
s = v[t][2] + s;
else if( q == 4 )
s = v[t][3] + s;
else
{
loop(i,0,q%5)
s = v[t][0] + s;
if( q >= 5 )
s = v[t][1] + s;
}
}
return s;
}
string toroman(int n) {
map<int, string> d;
d[1] = "I"; d[5] = "V"; d[10] = "X"; d[50] = "L"; d[100] = "C"; d[500] = "D"; d[1000] = "M"; d[4] = "IV"; d[9] = "IX"; d[40] = "XL"; d[90] = "XC"; d[400] = "CD"; d[900] = "CM";
string r;
while(n) {
map<int, string>::iterator it = d.lower_bound(n);
if(it->first > n) it--;
r += it->second;
n -= it->first;
}
return r;
}
а вот то, что я писал на контесте. Основное отличие в том, что константы догенерируются по начальным.
Офтоп.
Вот какие-то противоречивые чувства решение вызывает: с одной стороны симпатично, а с другой стороны тащить для такой задачи в программу STL с реализацией красно-черных деревьев как-то странно.
Это, наверное, с тех времен, когда на компьютере крутилась СВМ, под которой на одной виртуальной машине работала MVS, где считали зарплату и одовременно за терминалами в TSO работал десяток студентов, еще десяток работали в ПДО, еще на одной виртуальной машине крутилась МОС ЕС (это UNIX) со своим десятком пользователей.
И все это на одной ЕС-1036 с 4М памяти, процесором в 1Мгц и без особых тормозов =)
Да, времена изменились...
В Воронеже на Всероссийской студенчесской олимпиаде человек так 20 писали на одной машине. Предложенная MS VS 2010 запускалась минут 10. Затем секунд за 20 запускался диспетчер задач, ещё секунд 20 тратилось на убийство 2010 студии.
Запускаем 2008 студию - скорость увеличивается вдвое, но всё равно если набираешь строчку
for(int i=a;i<b;++i)
то появиться она может лишь секунд через 10 посе написания закрывающей скобки.
В итоге я не выдержал и писал в Borland'е.)