作者pplle (鱼)
看板Web_Design
标题[问题] Roman Numeral Converter
时间Wed May 24 00:00:56 2017
之前在练习freeCodeCamp上的题目遇到问题,想请问大家。
po错版麻烦请告知。
freeCodeCamp的题目是数字转罗马字。
我的程式如下:
var symbolCount = 0;
var rNum = 0;
var romanNStr = ""; //组出的罗马数字
function convertToRoman(num) {
rNum= num;
//先算开头M的个数
symbolCount = Math.floor(rNum/1000);
rNum = rNum -(1000*symbolCount);
for(var i = 0; i < symbolCount; i++ ){
romanNStr+="M";
}
calSymbol("M", "D", "C", 100);
calSymbol("C", "L", "X", 10);
calSymbol("X", "V", "I", 1);
return romanNStr;
}
//以三个为一组计算
function calSymbol(b, m, s, val){
symbolCount = Math.floor(rNum / val);
if(symbolCount == 9){
romanNStr += s + b;
rNum -= (9*val);
symbolCount = 0;
}
if(symbolCount == 4){
romanNStr += s + m;
rNum -= (4*val);
symbolCount = 0;
}
if(symbolCount >= 5){
romanNStr += m;
rNum -= (5 * val);
symbolCount -= 5;
}
for(var i = 0; i < symbolCount ; i++){
romanNStr += s;
rNum -= (1 * val);
}
}
================================
我知道我的程式不是最佳解,
但执行freeCodeCamp提供的[Run tests]按钮,仅有converToRoman(2)过关。
我自己也找不到问题,
麻烦高手跟我说我的程式哪里有问题,谢谢
freeCodeCamp的test如下
convertToRoman(2) should return "II".
convertToRoman(3) should return "III".
convertToRoman(4) should return "IV".
convertToRoman(5) should return "V".
convertToRoman(9) should return "IX".
convertToRoman(12) should return "XII".
convertToRoman(16) should return "XVI".
convertToRoman(29) should return "XXIX".
convertToRoman(44) should return "XLIV".
convertToRoman(45) should return "XLV"
convertToRoman(68) should return "LXVIII"
convertToRoman(83) should return "LXXXIII"
convertToRoman(97) should return "XCVII"
convertToRoman(99) should return "XCIX"
convertToRoman(500) should return "D"
convertToRoman(501) should return "DI"
convertToRoman(649) should return "DCXLIX"
convertToRoman(798) should return "DCCXCVIII"
convertToRoman(891) should return "DCCCXCI"
convertToRoman(1000) should return "M"
convertToRoman(1004) should return "MIV"
convertToRoman(1006) should return "MVI"
convertToRoman(1023) should return "MXXIII"
convertToRoman(2014) should return "MMXIV"
convertToRoman(3999) should return "MMMCMXCIX"
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 112.104.32.17
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Web_Design/M.1495555259.A.613.html
※ 编辑: pplle (112.104.32.17), 05/24/2017 00:02:33
2F:→ pplle: 很抱歉,还是看不出来…程式码我看过N次了Orz... 05/24 20:49
3F:→ EPGo: 检查console发现呼叫多次会因为 romanNStr 没有清空导致 05/24 21:59
4F:→ EPGo: return出来的答案错误 EX: convertToRoman(2) = II 05/24 22:00
5F:→ EPGo: 再 convertToRoman(3) 却变成 IIIII 05/24 22:01
6F:→ EPGo: 我直觉想法是再多一个变数来储存输出的值,求出答案将答案给 05/24 22:03
7F:→ EPGo: 该变数,并且清空 romanNStr 以便下次计算 05/24 22:04
9F:→ pplle: 太感谢E大了,有恍然大悟的感觉,晚上就来改我的程式,谢谢 05/25 16:53