layout: posttitle: Go和PHP 实现罗马数字转整数
subtitle: Go和PHP 实现罗马数字转整数
date: 2020-04-29
author: he xiaodong
header-img: img/default-post-bg.jpg
catalog: true
tags:
- Go
- PHP
- LeetCode
- 罗马数字转整数

原文链接:go leetcode,php 代码个人原创

罗马数字转整数(Roman-To-Integer)

题干:

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。
通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:
I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 的范围内。
示例 1:
输入: “LVIII”
输出: 58
解释: L = 50, V= 5, III = 3.
示例 2:
输入: “MCMXCIV”
输出: 1994
解释: M = 1000, CM = 900, XC = 90, IV = 4.
来源:力扣

题目有点长,耐心读一下哦,整体来说是比较简单的。

解题思路

根据题意我们可以知道单个罗马字母和数字的映射关系,例如 V 表示 数字 5,只是这里有一个问题: 罗马字母的组合形式对应的数字并不是单个罗马字母对应的数字之和。 例如 CD 对应的数字是 400,而单个 C 对应的数字为 100,单个 D 对应的数字为 500

根据规律可以发现(当然题干也明确说明了),当罗马数字中小数在大数左边时,所表示的数等于大数减去小数的值。 例如 CD 对应的数字是 单个 D 对应的数值减去单个 C 对应的数值,即 500 - 100 = 400。所以我们只需要遍历目标字符串,判断当前的罗马字符对应的数值 cur 与下一个罗马字符对应的数值 next 的大小,cur 小于 next减去 cur 的值,反之则 加上 cur 的值

流程图如下:
2020-04-29-Go和PHP 实现罗马数字转整数 - 图1

Go 实现

  1. // 罗马数字转成整数
  2. func getIntByRoman(r byte) int {
  3. switch r {
  4. case 'I':
  5. return 1
  6. case 'V':
  7. return 5
  8. case 'X':
  9. return 10
  10. case 'L':
  11. return 50
  12. case 'C':
  13. return 100
  14. case 'D':
  15. return 500
  16. case 'M':
  17. return 1000
  18. default:
  19. return 0
  20. }
  21. }
  22. func romanToInt(s string) int {
  23. res := 0
  24. i := 0
  25. // 跳出循环之后,i刚好指向字符串s的最后一个字符
  26. for ; i < len(s)-1; i ++ {
  27. cur := getIntByRoman(s[i])
  28. next := getIntByRoman(s[i+1])
  29. // 比较值,如果当前值比下一个值小则减去当前值,反之则加上当前值
  30. if cur < next {
  31. res -= cur
  32. } else {
  33. res += cur
  34. }
  35. }
  36. // 注意最后一个值需要加上
  37. res += getIntByRoman(s[i])
  38. return res
  39. }

PHP 实现

function getIntByRoman(string $r) {
    switch ($r) {
        case 'I':
            return 1;
            break;
        case 'V':
            return 5;
            break;
        case 'X':
            return 10;
            break;
        case 'L':
            return 50;
            break;
        case 'C':
            return 100;
            break;
        case 'D':
            return 500;
            break;
        case 'M':
            return 1000;
            break;
        default:
            return 0;
            break;
    }
}

function romanToInt(string $str) :string {
    $res = 0;
    // 跳出循环之后,i刚好指向字符串s的最后一个字符
    for ($i = 0; $i < strlen($str) - 1; $i ++) {
        $cur= getIntByRoman($str[$i]);
        $next = getIntByRoman($str[$i+1]);
        // 比较值,如果当前值比下一个值小则减去当前值,反之则加上当前值
        if ($cur < $next) {
            $res -= $cur;
        } else {
            $res += $cur;
        }
    }
    // 注意最后一个值需要加上
    $res += getIntByRoman($str[$i]);
    return $res;
}

return romanToInt('MCMXCIV'); // output: 1994

PHP 实现2 来自 laravel china 社区用户 yzh52521

function romanToInt($s) {
    $arr = [
        'I' => 1,
        'V' => 5,
        'X' => 10,
        'L' => 50,
        'C' => 100,
        'D' => 500,
        'M' => 1000
    ];
    $res = 0;
    for($i = 0; $i < strlen($s); $i++){
        if(!empty($arr[$s[$i+1]]) && $arr[$s[$i+1]] > $arr[$s[$i]]){
            $res += $arr[$s[$i+1]] - $arr[$s[$i]];
            $i += 1;//往前推移2位
        }else{
            $res += $arr[$s[$i]];
        }
    }
    return $res;
}

return romanToInt('MCMXCIV'); // output: 1994

最后恰饭 阿里云全系列产品/短信包特惠购买 中小企业上云最佳选择 阿里云内部优惠券