leetcode 13ローマ数字回転整数(go実現
ローマ数字には、I、V、X、L、C、D、Mの7文字が含まれています.
文字値I 1 V 5 X 10 L 50 C 100 D 500 M 1000は、例えば、ローマ数字2をIIと書くと、2つの並列の1となる.12はXIIと書きます.つまりX+IIです.27 XXVIIと書くと、XX+V+IIとなります.
通常、ローマ数字の中で小さい数字は大きな数字の右側にあります.しかし、例えば4はIIIではなくIVと書くという特例もある.数字1は数字5の左側にあり、表す数は大数5から小数1を減らした数値4に等しい.同様に、数字9はIXとして表される.この特殊なルールは、次の6つの場合にのみ適用されます.
IはV(5)とX(10)の左側に置いて4と9を表すことができる.XはL(50)とC(100)の左側に置いて40と90を表すことができる.CはD(500)とM(1000)の左側に置いて400と900を表すことができる.ローマ数字を指定し、整数に変換します.入力は1~3999の範囲であることを確認します.
例1:
入力:III出力:3例2:
入力:IV出力:4例3:
入力:IX出力:9例4:
入力:「LVIII」出力:58解釈:L=50,V=5,III=3.例5:
入力:「MCMXCIV」出力:1994解釈:M=1000,CM=900,XC=90,IV=4.
go言語は、特殊なすべてのマッチングを先に再循環して残りの単文字をマッチングすることを考えています.ここでは特殊な文字が一度現れます.方法は愚かです.もっと良いgo言語の解決方法があれば、提案することができます.
文字値I 1 V 5 X 10 L 50 C 100 D 500 M 1000は、例えば、ローマ数字2をIIと書くと、2つの並列の1となる.12はXIIと書きます.つまりX+IIです.27 XXVIIと書くと、XX+V+IIとなります.
通常、ローマ数字の中で小さい数字は大きな数字の右側にあります.しかし、例えば4はIIIではなくIVと書くという特例もある.数字1は数字5の左側にあり、表す数は大数5から小数1を減らした数値4に等しい.同様に、数字9はIXとして表される.この特殊なルールは、次の6つの場合にのみ適用されます.
IはV(5)とX(10)の左側に置いて4と9を表すことができる.XはL(50)とC(100)の左側に置いて40と90を表すことができる.CはD(500)とM(1000)の左側に置いて400と900を表すことができる.ローマ数字を指定し、整数に変換します.入力は1~3999の範囲であることを確認します.
例1:
入力:III出力:3例2:
入力:IV出力:4例3:
入力:IX出力:9例4:
入力:「LVIII」出力:58解釈:L=50,V=5,III=3.例5:
入力:「MCMXCIV」出力:1994解釈:M=1000,CM=900,XC=90,IV=4.
go言語は、特殊なすべてのマッチングを先に再循環して残りの単文字をマッチングすることを考えています.ここでは特殊な文字が一度現れます.方法は愚かです.もっと良いgo言語の解決方法があれば、提案することができます.
package main
import (
"fmt"
"strings"
)
func main() {
s := "III"
result := romanToInt(s)
fmt.Println(result)
}
func romanToInt(s string) int {
result := 0
if result1 := strings.Index(s, "CD"); result1 != -1 {
result += 400
s = strings.Replace(s, "CD","",1)
}
if result2 := strings.Index(s,"CM");result2 !=-1{
result += 900
s = strings.Replace(s,"CM","",1)
}
if result3 := strings.Index(s,"XL");result3 !=-1{
result += 40
s = strings.Replace(s,"XL","",1) // n ,-1
}
if result3 := strings.Index(s,"XC");result3 !=-1{
result += 90
s = strings.Replace(s,"XC","",1)
}
if result4 := strings.Index(s,"IV");result4 !=-1{
result += 4
s = strings.Replace(s,"IV","",1)
}
if result5 := strings.Index(s,"IX");result5 !=-1{
result += 9
s = strings.Replace(s,"IX","",1)
}
for _,value := range s{
// s[i] byte, ascii , string
ch := string(value)
if ch == "I"{
result += 1
s = strings.Replace(s,"I","",1)
}
if ch == "V"{
result += 5
s = strings.Replace(s,"V","",1)
}
if ch == "X"{
result += 10
s = strings.Replace(s,"X","",1)
}
if ch == "L"{
result += 50
s = strings.Replace(s,"L","",1)
}
if ch == "C"{
result += 100
s = strings.Replace(s,"C","",1)
}
if ch == "D"{
result += 500
s = strings.Replace(s,"D","",1)
}
if ch == "M"{
result += 1000
s = strings.Replace(s,"M","",1)
}
}
return result
}