summaryrefslogtreecommitdiff
path: root/0012/main.c
blob: 13c2c962455984b46524392114be359c0b64270f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include "stdlib.h"
#include "string.h"
#include "stdio.h"

typedef struct {
    int value;
    char *symbol;
} SymTableEntry;

SymTableEntry sym_table[] = {
    {1000, "M"},
    {900, "CM"},
    {500, "D"},
    {400, "CD"},
    {100, "C"},
    {90, "XC"},
    {50, "L"},
    {40, "XL"},
    {10, "X"},
    {9, "IX"},
    {5, "V"},
    {4, "IV"},
    {1, "I"},
    {-1, NULL},
};

char *concat(char *prev, char *sym) {
    int prevlen = strlen(prev);
    int symlen = strlen(sym);
    char *res = malloc(prevlen + symlen + 1);
    memcpy(res, prev, prevlen);
    memcpy(res + prevlen, sym, symlen);
    res[prevlen + symlen] = '\0';
    free(prev);
    return res;
}

char* intToRoman(int num) {
    char *r = malloc(1);
    r[0] = '\0';
    while (num > 0) {
        for (int i = 0; ; i++) {
            if (sym_table[i].value < 0) break;
            if (sym_table[i].value <= num) {
                num -= sym_table[i].value;
                r = concat(r, sym_table[i].symbol);
                break;
            }
        }
    }
    return r;
}

int main() {
    printf("%s\n", intToRoman(1234));
    return 0;
}