这道题是LeetCode里的第12道题。

吐了,刚做完“罗马数字转整数”,现在又做这个。这个没什么想法,只能想到使用if语句嵌套,或者使用哈希表。但哈希表我还不熟练啊。先拿if嵌套练练手。

题目说道:

罗马数字包含以下七种字符: I, V, X, LCD 和 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:

输入: 3
输出: "III"

示例 2:

输入: 4
输出: "IV"

示例 3:

输入: 9
输出: "IX"

示例 4:

输入: 58
输出: "LVIII"
解释: L = 50, V = 5, III = 3.

示例 5:

输入: 1994
输出: "MCMXCIV"
解释: M = 1000, CM = 900, XC = 90, IV = 4.

代码有点恐怖,就跟楼梯一样还挺好看的233333333

代码如下:

class Solution {
public:
string intToRoman(int num) {
string roman;
while(num){
if(num>=1000){num-=1000;roman+='M';}
else{
if(num>=900){num-=900;roman+='C';roman+='M';}
else{
if(num>=500){num-=500;roman+='D';}
else{
if(num>=400){num-=400;roman+='C';roman+='D';}
else{
if(num>=100){num-=100;roman+='C';}
else{
if(num>=90){num-=90;roman+='X';roman+='C';}
else{
if(num>=50){num-=50;roman+='L';}
else{
if(num>=40){num-=40;roman+='X';roman+='L';}
else{
if(num>=10){num-=10;roman+='X';}
else{
if(num>=9){num-=9;roman+='I';roman+='X';}
else{
if(num>=5){num-=5;roman+='V';}
else{
if(num>=4){num-=4;roman+='I';roman+='V';}
else{num-=1;roman+='I';}
}
}
}
}
}
}
}
}
}
}
}
}
return roman;
}
};
//你可以换个方式看23333
/*
class Solution {
public:
string intToRoman(int num) {
string roman;
while(num){
if(num>=1000){num-=1000;roman+='M';}
else{if(num>=900){num-=900;roman+='C';roman+='M';}
else{if(num>=500){num-=500;roman+='D';}
else{if(num>=400){num-=400;roman+='C';roman+='D';}
else{if(num>=100){num-=100;roman+='C';}
else{if(num>=90){num-=90;roman+='X';roman+='C';}
else{if(num>=50){num-=50;roman+='L';}
else{if(num>=40){num-=40;roman+='X';roman+='L';}
else{if(num>=10){num-=10;roman+='X';}
else{if(num>=9){num-=9;roman+='I';roman+='X';}
else{if(num>=5){num-=5;roman+='V';}
else{if(num>=4){num-=4;roman+='I';roman+='V';}
else{num-=1;roman+='I';}}}}}}}}}}}}}return roman;
}
};
*/

我数数了数总共12层if。还行,没有难度!

看那些比我快的都是使用哈希表,或者是使用千百十位从大到小分别判断,循环,遍历。

当然,也有不少用判断语句的,if+else if+else或者switch+case。但像这样if+else到底的只有我一个吧。

提交结果:

个人总结:

题目不难,不想写if语句的话可以用表映射。代码如下:

class Solution {
public:
string m[4][10] = \
{{"","M","MM","MMM"},
{"","C","CC","CCC","CD","D","DC","DCC","DCCC","CM"},
{"","X","XX","XXX","XL","L","LX","LXX","LXXX","XC"},
{"","I","II","III","IV","V","VI","VII","VIII","IX"}}; int d[4] = {1000,100,10,1}; string intToRoman(int num) {
string ans = "";
int i = 0;
for (auto v : d){
ans += m[i++][num/v];
num %= v;
}
return ans;
}
};
static const auto __false_nullptr = []() {
std::ios::sync_with_stdio(false);
std::cin.tie(nullptr);
return nullptr;
}();

二维数组m就是表格。每一行分别代表千、百、十、个位。也是一种比较好的解题方法。来源:Click

【LeetCode】Integer to Roman(整数转罗马数字)的更多相关文章

  1. [LeetCode] 12. Integer to Roman 整数转为罗马数字

    Roman numerals are represented by seven different symbols: I, V, X, L, C, D and M. Symbol Value I 1 ...

  2. lintcode :Integer to Roman 整数转罗马数字

    题目 整数转罗马数字 给定一个整数,将其转换成罗马数字. 返回的结果要求在1-3999的范围内. 样例 4 -> IV 12 -> XII 21 -> XXI 99 -> XC ...

  3. [LeetCode] Integer to Roman 整数转化成罗马数字

    Given an integer, convert it to a roman numeral. Input is guaranteed to be within the range from 1 t ...

  4. 【LeetCode】12. Integer to Roman 整数转罗马数字

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 个人公众号:负雪明烛 本文关键词:roman, 罗马数字,题解,leetcode, 力扣, ...

  5. [leetcode]12. Integer to Roman整数转罗马数字

    Roman numerals are represented by seven different symbols: I, V, X, L, C, D and M. Symbol Value I 1 ...

  6. Leetcode12.Integer to Roman整数转罗马数字

    罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即为两个并 ...

  7. [LintCode] Integer to Roman 整数转化成罗马数字

    Given an integer, convert it to a roman numeral. The number is guaranteed to be within the range fro ...

  8. LeetCode: Integer to Roman 解题报告

    Integer to Roman Given an integer, convert it to a roman numeral. Input is guaranteed to be within t ...

  9. Leetcode12--->Integer to Roman(整数转换为罗马数字)

    题目: 给定一个整数,将其转换为罗马数字; 题目很简单,主要是依靠整数和罗马数字的对应表: I= 1:V= 5: X = 10: L = 50: C = 100: D = 500: M = 1000 ...

随机推荐

  1. Ajax基础介绍

      什么是Ajax 首先来看一下什么是Ajax,英语全称Asynchronous JavaScript And XML,翻译成中文就是异步的JavaScript和XML.也被称为异步无刷新技术 先来解 ...

  2. Web Scalability for Startup Engineers Tip&Techniques for Scaling You Web Application --读书笔记

    Web Scalability for Startup Engineers Tip&Techniques for Scaling You Web Application 第1章和第2章讲述可伸 ...

  3. Springboot2.X集成Quartz集群

    为什么要使用Quzrtz集群 在项目进行集群部署时,如果业务在执行中存在互斥关系,没有对定时任务进行统一管理,就会引起业务的多次执行,不能满足业务要求.这时就需要对任务进行管理,要保证一笔业务在所有的 ...

  4. 3、从尾到头打印链表------------>剑指offer系列

    题目 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 分析 要了解链表的数据结构: val属性存储当前的值,next属性存储下一个节点的引用. 要遍历链表就是不断找到当前节点的nex ...

  5. IE下的圆角

    元素{ position: relative;/*必须*/ z-index: 10;/*必须*/ border-radius: 8px; -moz-border-radius: 8px; -webki ...

  6. OutOfMemory

    查看图片格式,如果为PNG,可更改为jpg.图片会变小. 停止activity 当activity调用onStop()方法, activity不再可见,并且应该释放那些不再需要的所有资源.一旦acti ...

  7. FusionCharts3.2.1 参数的详细说明和功能特性

    功能特性animation                    是否动画显示数据,默认为1(True)showNames                 是否显示横向坐标轴(x轴)标签名称rotat ...

  8. 洛谷 P1311 选择客栈

    题目描述 丽江河边有n 家很有特色的客栈,客栈按照其位置顺序从 1 到n 编号.每家客栈都按照某一种色调进行装饰(总共 k 种,用整数 0 ~ k-1 表示),且每家客栈都设有一家咖啡店,每家咖啡店均 ...

  9. C++11:移动构造函数的测试

    C++11:移动构造函数的测试 代码如下: #include <iostream> #include <stddef.h> #include <Windows.h> ...

  10. Jascript原型链以及Object和Function之间的关系

    先看一个简单的function变量 function fun1(name) { this.name = name; } console.log("fun1", fun1) 从结果可 ...