首页 > 其他 > 详细

13.罗马数字转成整形 Roman to Integer

时间:2017-01-11 07:46:01      阅读:284      评论:0      收藏:0      [点我收藏+]

Given a roman numeral, convert it to an integer.

Input is guaranteed to be within the range from 1 to 3999.


  1. public class Solution {
  2. public int RomanCharToInt(char c)
  3. {
  4. switch (c)
  5. {
  6. case ‘I‘:
  7. return 1;
  8. case ‘V‘:
  9. return 5;
  10. case ‘X‘:
  11. return 10;
  12. case ‘L‘:
  13. return 50;
  14. case ‘C‘:
  15. return 100;
  16. case ‘D‘:
  17. return 500;
  18. case ‘M‘:
  19. return 1000;
  20. default:
  21. return 0;
  22. }
  23. }
  24. public int RomanToInt(string s)
  25. {
  26. int length = s.Length;
  27. int i = length - 1;
  28. int sum = RomanCharToInt(s[i--]);
  29. while (i >= 0)
  30. {
  31. if (RomanCharToInt(s[i + 1]) > RomanCharToInt(s[i]))
  32. {
  33. sum -= RomanCharToInt(s[i--]);
  34. }
  35. else
  36. {
  37. sum += RomanCharToInt(s[i--]);
  38. }
  39. }
  40. return sum;
  41. }
  42. }





13.罗马数字转成整形 Roman to Integer

原文:http://www.cnblogs.com/xiejunzhao/p/f551a60eb0fd4d8210746283bace7143.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!