当前位置: 首页 > news >正文

娄底网站建设工作室诸暨公司做网站

娄底网站建设工作室,诸暨公司做网站,用word文档做网站,网站外链怎么购买关键词:to_string, string.size(), string.length() 1.题目 2.解答思路及解答 解答思路: 首先,罗马数字表达中和常规数学表达类似,基本是按照从后往前,从小到大排列。因此,理论上只需要从后往前相加即可。…

 关键词:to_string, string.size(), string.length()

1.题目

2.解答思路及解答

解答思路:

        首先,罗马数字表达中和常规数学表达类似,基本是按照从后往前,从小到大排列。因此,理论上只需要从后往前相加即可。

        受限于几种特殊情况,根据相加的顺序,如果是从小到大(从右往左,从下标大到小时),特殊情况IV,IX,XL,XC,CD,CM则特殊考虑,即遇到V、X判断左侧是否有I,否则特殊处理,没有I时正常处理,其他情况类似。

        需要注意的不仅是思路问题,本题从左往右相加也可计算,但是时刻需要注意下标溢出问题。

class Solution {
public:int romanToInt(string s) {int iSize = s.size();int iSum = 0;for(int i = iSize - 1; i >= 0; --i){if(s[i] == 'I'){iSum += 1;}else if(s[i] == 'V'){if(i-1 >= 0 && s[i-1] == 'I'){iSum += 4;--i;}else{iSum += 5;}}else if(s[i] == 'X'){if(i-1>=0 && s[i-1] == 'I'){iSum += 9;--i;}else{iSum += 10;}}else if(s[i] == 'L'){if(i-1>=0 && s[i-1] == 'X'){iSum += 40;--i;}else{iSum += 50;}}else if(s[i] == 'C'){if(i-1>=0 && s[i-1] == 'X'){iSum += 90;--i;}else{iSum += 100;}}else if(s[i] == 'D'){if(i-1>=0 && s[i-1] == 'C'){iSum += 400;--i;}else{iSum += 500;}}else if(s[i] == 'M'){if(i-1>=0 && s[i-1] == 'C'){iSum += 900;--i;}else{iSum += 1000;}}//end for}return iSum;//end fun}
//end class
};

3.优秀答案

答案1:map比对

        该答案中利用map解决了常规思路中需要逐个if判断字母和对应特殊情况的问题(理论上switch就是多个if的语句,可以替代if,然而switch只能分类数字,而不能进行字母分类)。

        而且巧妙总结了罗马数字的规律:如果小的数字放在大数字左边就等于大数字减小数字的结果。

class Solution {
private:unordered_map<char, int> symbolValues = {{'I', 1},{'V', 5},{'X', 10},{'L', 50},{'C', 100},{'D', 500},{'M', 1000},};public:int romanToInt(string s) {int ans = 0;int n = s.length();for (int i = 0; i < n; ++i) {int value = symbolValues[s[i]];if (i < n - 1 && value < symbolValues[s[i + 1]]) {ans -= value;} else {ans += value;}}return ans;}
};作者:力扣官方题解
链接:https://leetcode.cn/problems/roman-to-integer/solutions/774992/luo-ma-shu-zi-zhuan-zheng-shu-by-leetcod-w55p/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

4.技术总结

1

unordered_map<char,int> XXX={

{‘I’,1},

{‘V’,5},

{‘X’,10},

}

map,XXX[char]返回int

http://www.yayakq.cn/news/420109/

相关文章:

  • 苏州网站设计公司官网开发网站设计公司
  • 淘宝网电脑版登录旺道seo优化软件
  • jquery特效的网站小程序定制 seo营销
  • 网站后台编辑器什么类型的网站流量高
  • 四川省建设工程质量监督总站网站wordpress资源管理
  • 手机 网站开发软件有哪些专业的网站建设宝安西乡
  • 网站规划的意义硬件开发技术
  • 虚拟主机如何分配网站如何注册品牌名称和商标
  • 企业网站建设知识应用技能小程序开发平台有哪些
  • wordpress 搭建博客网站值不值得做seo
  • 做网站建设有哪些公司重庆做网站优化
  • 主机屋 大网站洛阳网站推广优化
  • 自己做的微信网站经常被停止访问建设一个公司网站需要什么条件
  • 电商网站建设计入什么科目南宁有名的seo费用
  • 河池企业网站开发公司app网站设计
  • 网站域名解析查询成免费的crm
  • 株洲做网站网站集约化建设探讨
  • 网站管理是做什么的wordpress运行环境搭建以及安装
  • 作品展示的网站网站发展历程
  • 长沙建网站的公司一对一定制方案iis配置网站无法访问
  • 有没有哪种网站推荐一下哪个国家的绘本网站做的好
  • jquery 单页网站引流用什么话术更吸引人
  • 红安建设局官方网站军事网站大全军事网
  • 女孩做网站工作辛苦吗宜兴网站优化
  • 饰品网站模版郑州seo网站排名优化公司
  • 在internet上建设网站建网站主要工具
  • 泰安网网站建设网站开发和合同范本
  • 高品质网站设计制作网站设计方案应该怎么做
  • 帝国网站教程自己的电脑做服务区 网站
  • 关于苏宁易购网站建设的不足之处区网站建设