【问题标题】:Convert roman numerals to decimal value error将罗马数字转换为十进制值错误
【发布时间】:2018-10-24 14:06:07
【问题描述】:

下面我尝试编写一个程序将罗马数字转换为十进制值,但我似乎无法弄清楚为什么当我输入测试值时 MCMLXXVIII 它会打印出 1088 而不是 1978。如果有人能告诉我哪里出了问题,将不胜感激。

import java.util.Scanner;
public class RomanNumerals {

public static void main(String[] args) {
    Scanner console =  new Scanner(System.in);
    int total = 0, strLength;

    String romanNum;
    System.out.print("Enter roman numeral to convert: ");

    romanNum = console.next();
    total = convertNum(romanNum);

    System.out.println("The roman numeral converted is: " + total);
    console.close();
}

public static int convertNum(String romanNum) {
    int total = 0;
    while (!romanNum.isEmpty())  {
        if ((romanNum.length() == 1) || valueOf(romanNum.charAt(0)) >= 
        valueOf(romanNum.charAt(1))) {
            total += valueOf(romanNum.charAt(0));
            romanNum = romanNum.substring(1);
        } else {
            total += (romanNum.charAt(1)) - (romanNum.charAt(0));
            romanNum = romanNum.substring(2);
        }
    }
    return total;
}

/**
 * Gives the value of the Roman numeral
 *   
 * @param numeral a single Roman numeral
 * @return the decimal value of numeral
 */
public static int valueOf(char numeral) {
    if (numeral == 'I') {
        return 1;
    }
    if (numeral == 'V') {
        return 5;
    }
    if (numeral == 'X') {
        return 10;
    }
    if (numeral == 'L') {
        return 50;
    }
    if (numeral == 'C') {
        return 100;
    }
    if (numeral == 'D') {
        return 500;
    }
    // must be an M
    return 1000;
    }
}

我确信有更简单的方法可以使用数组或其他东西来做到这一点,但是对于我目前正在学习的课程,我们不允许使用数组,我们必须使用基本的 Java 东西,比如方法和循环,但不是数组,因为我们还没有得到它们。

【问题讨论】:

  • 方法 valueOf 必须有两个参数 valueOf(char numeric, char nextNumeral)。 if (numeral == 'C' && nextNumeral == 'M') {return 900;}
  • @Ilya OP 为此使用 convertNum 中的 else 分支。
  • 完全忘记了那些静脉注射等情况......哇
  • @liam12808 不,你没有。还是那不是你的代码?

标签: java methods numbers java.util.scanner roman-numerals


【解决方案1】:

您忘记在else 分支中调用valueOf()

...

} else {
    total += valueOf(romanNum.charAt(1)) - valueOf(romanNum.charAt(0));
    romanNum = romanNum.substring(2);
}

【讨论】:

    猜你喜欢
    • 2017-11-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-01-09
    相关资源
    最近更新 更多