• qaz@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 months ago

      I’m pretty sure it’s Java (due to the syntax and Eclipse editor default color scheme), so that isn’t an issue

  • rooroo@feddit.org
    link
    fedilink
    arrow-up
    0
    ·
    2 months ago

    It also works the other way round: wanna convert Arabic n to Roman? Just write n times ‘I’ and revert these replacement in inverse order.

    • lugal@lemmy.dbzer0.com
      link
      fedilink
      arrow-up
      0
      ·
      2 months ago

      I don’t know what happens when the substring overlaps. Like for the number 6, will it replace the first 5 I’s with V and end up correctly with VI or the last ones and come to IV? I would guess the former and maybe you know but I never thought about it before

      • rooroo@feddit.org
        link
        fedilink
        arrow-up
        0
        ·
        2 months ago

        I’ve written it that way and it works, as in it will replace left to right and you replace iiii to iv after iiiii to v

        • lugal@lemmy.dbzer0.com
          link
          fedilink
          arrow-up
          0
          ·
          2 months ago

          Makes sense but it will fail at 9 (VIV) it would only work for 9 if the replace went from right to left or the V and IV statements were exchanged but in both cases, 6 would fail

          • rooroo@feddit.org
            link
            fedilink
            arrow-up
            0
            ·
            2 months ago

            9 is IX though, and that works.

            6 works fine, as it replaces the first set of 5 I with V and then there’s nothing to replace.

            I’d written it in typescript for all it’s worth; go ahead and try it yourself :)

              • rooroo@feddit.org
                link
                fedilink
                arrow-up
                0
                ·
                2 months ago

                No, cause you do the replacement from large to small, I.e. you’d first check for 10 I to replace with X (none found); then replace 9 with IX (check), then check for 5, 4 and so on.

                • lugal@lemmy.dbzer0.com
                  link
                  fedilink
                  arrow-up
                  0
                  ·
                  2 months ago

                  The original doesn’t have an extra check for 9 and it works for Roman->Indioarabic because it’s:

                  IX
                  ->IVV
                  ->IIIIV
                  ->IIIIIIIII
                  

                  But the other way around, you need an extra step for 9. That’s where our misunderstanding comes from.

              • rooroo@feddit.org
                link
                fedilink
                arrow-up
                0
                ·
                2 months ago

                I like your questions about this and they all seem fair but I kinda wanna encourage you to go ahead and write it yourself; it’s a fun way to convert into Roman numerals that both is and isn’t intuitive at the same time.

  • CookieOfFortune@lemmy.world
    link
    fedilink
    arrow-up
    0
    ·
    2 months ago

    This isn’t sufficiently enterprisey for Java. There should be a Roman numeral factory followed by relevant fromString and toInteger methods.

    • vithigar@lemmy.ca
      link
      fedilink
      arrow-up
      0
      ·
      2 months ago

      Ugh. Literally refactored multiple factories into straightforward functions in the most recent sprint where I work.

      Someone saw a public factory method which was a factory for a reason and just cargo culted multiple private methods using the same pattern.

  • Caveman@lemmy.world
    link
    fedilink
    arrow-up
    0
    ·
    2 months ago

    It’s not too bad, it’s readable and easily optimised by adding intermediate sums and removing whatever power of 10 you’re working on.

  • mkwt@lemmy.world
    link
    fedilink
    arrow-up
    0
    ·
    2 months ago

    You missed “CM,” which was common in copyright statements in the 20th century.

    • trxxruraxvr@lemmy.world
      link
      fedilink
      arrow-up
      0
      ·
      edit-2
      2 months ago

      No, M will be replaced by DD and then CD will be picked up, so it will go

      1. CM
      2. CDD
      3. CCCCD
      4. CCCCCCCCC
  • TootSweet@lemmy.world
    link
    fedilink
    English
    arrow-up
    0
    ·
    edit-2
    2 months ago

    My first thought was something along the lines of a “zip bomb”. For every “M” in the input string, it’d use more than a KiB of memory. But still, it’d take a string of millions of "M"s to exhaust memory on even a low-end modern server. Still probably not a good idea to expose to untrusted input on a public networked server, though. And it could easily peg a CPU core for a good while. Very good leveraged target for DDOSing.