Вот описание проблемы:
Напишите тестовую функцию toDecimal(), которая преобразует римские цифры, такие как MMLXVII, в их десятичное представление. Используйте main() для проверки функции.
Функция toDecimal() должна иметь 2 аргумента: строковый массив римских цифр и вспомогательную функцию. Эта вспомогательная функция вернет числовое значение каждой буквы, используемой в римских цифрах.
Затем преобразуйте строковые аргументы следующим образом: посмотрите на первые два символа, если первый больше, преобразуйте первый и добавьте его к суммированию, затем снова вызовите функцию преобразования со вторым значением и добавьте оба. ЕСЛИ первый символ меньше второго, вычтите первый из второго и добавьте результат к преобразованию строки. Без проверки это также преобразует строки типа "IC".
Проверьте строковый аргумент и, если есть ошибка, вызовите функцию обработки ошибок.
Предоставьте как минимум две функции обработки ошибок и протестируйте toDecimal() для каждой. Можно попросить пользователя исправить; другой может это исправить.
- I, X, C и M нельзя повторять более 3 раз подряд.
- D, L и V никогда нельзя повторять подряд.
- I можно вычесть только из V и X.
- X можно вычесть только из L и C.
- C можно вычесть только из D и M.
- V, L и D никогда нельзя вычесть.
Код: Выделить всё
#include
#include
#include
#include
#include
using namespace std;
bool checker(string roman);
// Adds each value of the roman numeral together
int toDecimal(string, bool* (*function)(string));
int convert(string roman, int i);
int main() {
string roman;
cout
Подробнее здесь: [url]https://stackoverflow.com/questions/17724887/c-converting-roman-numerals-to-decimals[/url]
Мобильная версия