• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

konwerter liczb arabskich na rzymskie

Object Storage Arubacloud
0 głosów
964 wizyt
pytanie zadane 4 lipca 2018 w Java przez periedynek Obywatel (1,320 p.)

Hej, to mój drugi już temat odnośnie tego tematu.

Piszę teraz zamianę liczb arabskich an rzymskie.

Napisałem coś takiego, ale domyślam się, że to boli w oczy i jest zahardkodowane, wiecie jak to może usprawnić?

 public static void main(String[] args) {

        int ArabicNumber = 1131;

        int tysiac = ArabicNumber / 1000;
        int setki = ArabicNumber / 100 % 10;
        int dziesiatki = ArabicNumber / 10 % 10;
        int jednosci = ArabicNumber % 10;

        StringBuilder RomanString = new StringBuilder();

        String RomanThousand = "M";
        String RomanHundred = "C";
        String RomanTen = "X";
        String RomanOne = "I";

        for (int i = 0; i < tysiac; i++) {
            RomanString.append(RomanThousand);
        }
        for (int i = 0; i < setki; i++) {
            if (setki > 3) {
                if (setki == 4) {
                    RomanString.append("CD");
                    break;
                }

                if (setki == 5) {
                    RomanString.append("D");
                    break;
                }
                if (setki == 6) {
                    RomanString.append("DC");
                    break;
                }
                if (setki == 7) {
                    RomanString.append("DCC");
                    break;
                }
                if (setki == 8) {
                    RomanString.append("DCCC");
                    break;
                }

                if (setki == 9) {
                    RomanString.append("CM");
                    break;
                }
            }
            RomanString.append(RomanHundred);
        }
        for (int i = 0; i < dziesiatki; i++) {
            if (dziesiatki > 3) {
                if (dziesiatki == 4) {
                    RomanString.append("XL");
                    break;
                }
                if (dziesiatki == 5) {
                    RomanString.append("L");
                    break;
                }
                if (dziesiatki == 6) {
                    RomanString.append("LX");
                    break;
                }
                if (dziesiatki == 7) {
                    RomanString.append("LXX");
                    break;
                }
                if (dziesiatki == 8) {
                    RomanString.append("LXXX");
                    break;
                }
                if (dziesiatki == 9) {
                    RomanString.append("XC");
                    break;
                }
            }
            RomanString.append(RomanTen);
        }
        for (int i = 0; i < jednosci; i++) {
            if (jednosci > 3) {
                if (jednosci == 4) {
                    RomanString.append("IV");
                    break;
                }
                if (jednosci == 5) {
                    RomanString.append("V");
                    break;
                }
                if (jednosci == 6) {
                    RomanString.append("VI");
                    break;
                }
                if (jednosci == 7) {
                    RomanString.append("VII");
                    break;
                }
                if (jednosci == 8) {
                    RomanString.append("VIII");
                    break;
                }
                if (jednosci == 9) {
                    RomanString.append("IX");
                    break;
                }
            }
            RomanString.append(RomanOne);
        }

        System.out.println(RomanString);


    }

 

komentarz 4 lipca 2018 przez Mariusz08 Maniak (62,300 p.)
String RomanThousand = "M";
       String RomanHundred = "C";
       String RomanTen = "X";
       String RomanOne = "I";

Nie widzę RomanFive

komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)
edycja 4 lipca 2018 przez periedynek
Bo u mnie to nie jest potrzebne. Popatrz jak działają u mnie pętle.

1 odpowiedź

+2 głosów
odpowiedź 4 lipca 2018 przez Mateusz51 Nałogowiec (28,180 p.)
wybrane 4 lipca 2018 przez periedynek
 
Najlepsza
Jak już używasz takiej ilości ifów i nawet z break to zamień to na switch case
komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)

takie coś zrobiłem, ale nie działa nie wiedzieć czemu:

public static void main(String[] args) {

        int ArabicNumber = 990;

        int thousand = ArabicNumber / 1000;
        int hundred = ArabicNumber / 100 % 10;
        int tens = ArabicNumber / 10 % 10;
        int units = ArabicNumber % 10;

        StringBuilder RomanString = new StringBuilder();

        String RomanThousand = "M";
        String RomanHundred = "C";
        String RomanTen = "X";
        String RomanOne = "I";

        for (int i = 0; i < thousand; i++) {
            RomanString.append(RomanThousand);
        }

        for (int i = 0; i < hundred; i++) {
            if (hundred > 3) {
                switch (hundred) {
                    case 4: {
                        RomanString.append("CD");
                        break;
                    }
                    case 5: {
                        RomanString.append("D");
                        break;
                    }
                    case 6: {
                        RomanString.append("DC");
                        break;
                    }
                    case 7: {
                        RomanString.append("DCC");
                        break;
                    }
                    case 8: {
                        RomanString.append("DCCC");
                        break;
                    }
                    case 9: {
                        RomanString.append("CM");
                        break;
                    }
                }
            }
            RomanString.append(RomanHundred);
        }

        for (int i = 0; i < tens; i++) {
            if (tens > 3) {
                switch (tens) {
                    case 4: {
                        RomanString.append("XL");
                        break;
                    }
                    case 5: {
                        RomanString.append("L");
                        break;
                    }
                    case 6: {
                        RomanString.append("LX");
                        break;
                    }
                    case 7: {
                        RomanString.append("LXX");
                        break;
                    }
                    case 8: {
                        RomanString.append("LXXX");
                        break;
                    }
                    case 9: {
                        RomanString.append("XC");
                        break;
                    }
                }
            }
            RomanString.append(RomanTen);
        }

        for (int i = 0; i < units; i++) {
            if (units > 3) {
                switch (units) {
                    case 4: {
                        RomanString.append("IV");
                        break;
                    }
                    case 5: {
                        RomanString.append("V");
                        break;
                    }
                    case 6: {
                        RomanString.append("VI");
                        break;
                    }
                    case 7: {
                        RomanString.append("VII");
                        break;
                    }
                    case 8: {
                        RomanString.append("VIII");
                        break;
                    }
                    case 9: {
                        RomanString.append("IX");
                        break;
                    }
                }
            }
            RomanString.append(RomanOne);
        }
        System.out.println(RomanString);
    }

 

komentarz 4 lipca 2018 przez Mateusz51 Nałogowiec (28,180 p.)
case nie musi mieć nawiasów
komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)
przejrzyście to wygląda wtedy, ale to chyba nie jest przyczyna?
komentarz 4 lipca 2018 przez Mateusz51 Nałogowiec (28,180 p.)
nie wiem co Ci nie działa
komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)
Już ogarnąłem, bo przedtem przy ifach break mi wychodził z całej pętli for, a tereaz przy case break wychodzi z samego switcha, wiec Twoja opcja chyba nie dziala.
komentarz 4 lipca 2018 przez Mateusz51 Nałogowiec (28,180 p.)
a po co Ci for jak z niego wychodzisz?  Nie lepiej dać do switch default w którym to uzyjesz fora do dadania odpowiedniej ilosci znaków?

dzięki temu pozbędziesz się zagnieżdżenia ifów
komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)

A okej, o to Ci chodziło?

if (tens > 3) {
            switch (tens) {
                case 4: {
                    RomanString.append("XL");
                    break;
                }
                case 5: {
                    RomanString.append("L");
                    break;
                }
                case 6: {
                    RomanString.append("LX");
                    break;
                }
                case 7: {
                    RomanString.append("LXX");
                    break;
                }
                case 8: {
                    RomanString.append("LXXX");
                    break;
                }
                case 9: {
                    RomanString.append("XC");
                    break;
                }
                default: {
                    for (int i = 0; i < tens; i++) {
                        RomanString.append(RomanTen);
                    }
                }
            }
        }

 

1
komentarz 4 lipca 2018 przez Mateusz51 Nałogowiec (28,180 p.)
tak i zastanów się czy ten if na początku jest Ci potrzebny?
komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)
tez prawda.

Dzieki wielkie.

Tylko tyle da się zmienić w moim kodzie?
komentarz 4 lipca 2018 przez Mateusz51 Nałogowiec (28,180 p.)
według konwencji javowych nie powinno nazywac sie zmiennych z wielkich liter.

Ale generalnie jak pozbyłeś się zagnieżdżonych ifów to jest okej. Nie ma co walczyc o perfekcyjny kawałek kodu gdy masz jeszcze wiele rzeczy do nauczenia

ewentualnie porozdzielaj to na funkcje
komentarz 4 lipca 2018 przez periedynek Obywatel (1,320 p.)
Faktycznie. Dzięki! :)

Podobne pytania

0 głosów
0 odpowiedzi 526 wizyt
0 głosów
1 odpowiedź 560 wizyt
0 głosów
0 odpowiedzi 653 wizyt
pytanie zadane 6 maja 2021 w C i C++ przez Holdapia Nowicjusz (140 p.)

92,624 zapytań

141,482 odpowiedzi

319,822 komentarzy

62,005 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...