2019-03-1-算法-进化(整数转罗马数字)

题目描述
罗马数字包含以下七种字符: I, V, X, L,C,D 和 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.

我的初步解答:

public String intToRoman(int num) {StringBuilder sb = new StringBuilder();Map<Integer, String> map = new HashMap<Integer, String>();map.put(1000, "M");map.put(900, "CM");map.put(500, "D");map.put(400, "CD");map.put(100, "C");map.put(90, "XC");map.put(50, "L");map.put(40, "XL");map.put(10, "X");map.put(9, "IX");map.put(5, "V");map.put(4, "IV");map.put(1, "I");int head =0;while (num>0) {if(num/1000 != 0) {head = num/1000;num -=head*1000;while(head >0) {sb.append(map.get(1000));head--;}}else if (num/900 !=0) {sb.append(map.get(900));num-=900;}else if (num/500 !=0) {sb.append(map.get(500));num-=500;}else if (num/400 !=0) {sb.append(map.get(400));num-=400;}else if (num/100 !=0) {head = num/100;num -=head*100;while(head >0) {sb.append(map.get(100));head--;}}else if (num/90 !=0) {sb.append(map.get(90));num-=90;}else if (num/50 !=0) {sb.append(map.get(50));num-=50;}else if (num/40 !=0) {sb.append(map.get(40));num-=40;}else if (num/10 !=0) {head = num/10;num -=head*10;while(head >0) {sb.append(map.get(10));head--;}}else if (num/9 !=0) {sb.append(map.get(9));num-=9;}else if (num/5 !=0) {sb.append(map.get(5));num-=5;}else if (num/4 !=0) {sb.append(map.get(4));num-=4;}else if (num/1 !=0) {head = num/1;num -=head;while(head >0) {sb.append(map.get(1));head--;}}}return sb.toString();}

观察上面的代码,发现这一大串if else if特别的啰嗦,并且处理逻辑基本相同,所以,优化方向就出来了,整合这些逻辑分支为同一个。
考虑到需要一个有序的key-value的数据结构,在TreeMap与LinkedHashMap之间选。

  • LinkedHashMap:底层为链表,元素顺序为写入时候的顺序;
  • TreeMap:元素顺序可以通过实现Comparator接口自定义,默认为数字升序排列;

由于我们需要的是数字的降序排列,并且元素初始化顺序可以自定义,所以为方便,选取LinkedHashMap为本次的数据结构
改进之后的代码如下:

	public String intToRoman(int num) {StringBuilder sb = new StringBuilder();Map<Integer, String> map = new LinkedHashMap<Integer, String>() {private static final long serialVersionUID = 1L;{put(1000, "M");put(900, "CM");put(500, "D");put(400, "CD");put(100, "C");put(90, "XC");put(50, "L");put(40, "XL");put(10, "X");put(9, "IX");put(5, "V");put(4, "IV");put(1, "I");}};Set<Map.Entry<Integer, String>> set = map.entrySet();int head =0;while(num > 0) {for(Map.Entry<Integer, String> e: set) {if(num/e.getKey() != 0) {head = num/e.getKey();num -=head*e.getKey();while (head >0) {sb.append(e.getValue());head--;}break;}}}return sb.toString();}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314089.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

brz的函数(mobius)

brz的函数 ∑i1n∑j1nμ(ij)假设i,j不互质&#xff0c;一定有μ(ij)0所以上式∑i1n∑j1nμ(ij)[gcd(i,j)1]积性函数性质有μ(ij)μ(i)μ(j)∑i1n∑j1nμ(i)μ(j)[gcd(i,j)1]∑i1n∑j1nμ(i)μ(j)∑d∣gcd(i,j)μ(d)这里我们按照套路把d给提前去&#xff0c;因为i,j都要是d的倍数…

CF1251F Red-White Fence(多项式/背包问题/组合数学)

CF1251F Red-White Fence 现在给出了n个白板&#xff0c;m个红板&#xff0c;然后将其按照题目要求放成一排&#xff0c;要求最终周长为qi的方案数。 首先因为有高度的单调性&#xff0c;所以我们可以直接把周长转化为红板的高度和白板的数量&#xff0c;然后因为红板数量很少…

Java修炼之路——基础篇——枚举

枚举的用法 每个枚举变量其实都是枚举类的一个实例。 枚举与单例 各种模式的单例模式&#xff0c;包括枚举实现的单例 //懒汉模式 class SingletonA {private static SingletonA instance new SingletonA();//保证不能通过new SingletonB的方式创建对象private SingletonA()…

Docker(二)-在Docker中部署Nginx实现负载均衡【完整教程】

一、前言【查看完整视频教程&#xff08;免费&#xff09;&#xff0c;请拉直文尾】在前面的文章中我们已经介绍了如何在Centos7系统中安装Docker以及利用Docker进行Asp.Net Core应用的部署。在本文中&#xff0c;我们将继续介绍利用Docker部署Nginx服务实现负载均衡。文章最后…

HDU 6127 Hard challenge(极角 + 二分)

Hard challenge 思路 通过极角排序&#xff0c;这里通过修改后&#xff0c;所有点的角度在[0,2π)[0, 2 \pi)[0,2π)之间&#xff0c; 然后O(n)O(n)O(n)扫一趟&#xff0c;对当前在的级角加上π\piπ就是我们要找的角度了&#xff0c;这里通过二分来实现查找。 接下来就只要…

P2664 树上游戏(点分治/计数题计算贡献/树上差分)

P2664 树上游戏 对于树上n个点&#xff0c;每个点有不同颜色&#xff0c;求解每个点到其他点的路径上不同颜色个数之和。 首先看到这种树上点对问题&#xff0c;我们可以想到点分治&#xff0c;然后考虑每次分治如何求解答案&#xff0c;本质上就是一个数颜色的问题&#xff…

2019-03-4-算法-进化(罗马数字转整数)

题目描述 罗马数字包含以下七种字符: I&#xff0c; V&#xff0c; X&#xff0c; L&#xff0c;C&#xff0c;D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000例如…

设置ABP默认使用中文

ABP提供的启动模板, 默认使用是英文:虽然可以通过右上角的菜单切换成中文, 但是对于国内项目来说, 默认使用中文是很正常的需求.前期准备使用ABP CLI创建一个名为AbpStudy的ASP.NET MVC项目:abp new AbpStudy关于MVC的启动模板可以看文档, 这里就不赘述.使用ABP版本的是当前最新…

P3835 【模板】可持久化平衡树

P3835 【模板】可持久化平衡树 好久没有打平衡树了&#xff0c;赶紧来复习一下&#xff0c;平衡树这种东西还是很有用的&#xff0c;可以很灵活地解决一些问题。 fhq_treap 这道题是可持久化的权值平衡树&#xff0c;支持以下几个操作 1、 插入 xxx 2、 删除 xxx&#xff08…

基础篇--Java IO--概览

字符流、字节流、输入流、输出流 Java 中使用IO&#xff08;输入输出&#xff09;来读取和写入&#xff0c;读写磁盘文件、内存、网络数据。输入输出是相对内存而言&#xff0c;往内存中读数据就为输入流&#xff0c;从内存中往外写就是输出流。 根据处理类型分为字符流、字节…

半平面交练习(计算几何)

四&#xff1a;半平面交 Rotating Scoreboard /*Author : lifehappy */ #include <cstdio> #include <cmath> #include <cstring> #include <algorithm> #include <vector> #include <iostream>using namespace std;const double pi ac…

.NET轻松写博客园爬虫

爬虫&#xff0c;是一种按照一定的规则&#xff0c;自动地抓取网站的程序或者脚本。.NET写爬虫非常简单&#xff0c;并能轻松优化性能。今天我将分享一段简短的代码&#xff0c;爬出博客园前200页精华内容&#xff0c;然后通过微小的改动&#xff0c;将代码升级为多线程爬虫&am…

P5055 【模板】可持久化文艺平衡树

P5055 【模板】可持久化文艺平衡树 突然发现fhq_treap也是可以支持区间翻转的&#xff0c;所以基本上和其他平衡树是一样的&#xff0c;而且还满足重量平衡树的性质&#xff0c;真是太优秀了&#xff0c;只不过常数稍微比较大。 然后这里我们变成了一颗区间平衡树&#xff0c…

kettle同步数据中文乱码问题解决

最近在使用kettle进行数据同步的时候&#xff0c;发现同步来的中文数据产生了乱码。试了下网上的解决方案&#xff0c;最终解决了这个问题。步骤如下&#xff1a; 1&#xff1a;kettle中配置源数据库、目标数据库编码 2&#xff1a;编辑“表输入”&#xff0c;去掉勾选“允许建…

WTM重磅更新,LayuiAdmin免费用 and more

从善如登&#xff0c;从恶如崩。对于一个开发人员来说&#xff0c;那就是做一个好的系统不容易&#xff0c;想搞砸一个系统很简单&#xff0c;删库跑路会还不会么。对于我们开源框架的作者来说&#xff0c;做一个好的框架就像登山&#xff08;也许是登天&#xff09;&#xff0…

Lady Layton with Math(杜教筛)

Lady Layton with Math ∑i1n∑j1nϕ(gcd(i,j))∑d1nϕ(d)∑i1n∑j1n[gcd(i,j)d]∑d1nϕ(d)∑i1nd∑j1nd[gcd(i,j)1]∑d1nϕ(d)(2∑i1nd∑j1i[gcd(i,j)1]−1)∑d1nϕ(d)(2∑i1ndϕ(i)−1)\sum_{i 1} ^{n} \sum_{j 1} ^{n} \phi(gcd(i, j))\\ \sum_{d 1} ^{n} \phi(d) \sum_{…

概率期望复习

概率期望 P(A并B)P(A)P(B)-P(A交B) 条件概率 已知A发生B发生的概率&#xff0c;记作P(B|A) 四种情况 P(AB都发生)a,P(AB都不发生)b P(只有A发生)c,P(只有B发生)d P(B|A)a/(ac),即P(B|A)P(AB)/P(A) 全概率公式 P(A)P(B1)P(A|B1)…P(Bn)P(A|Bn) 三门问题 生日悖论 贝叶斯…

kettle数据库操作OPTION SQL_SELECT_LIMIT=DEFAULT问题解决

今天在使用kettle配置数据库映射的时候&#xff0c;有如下报错&#xff1a; Couldnt get field info from [select * from pre_user_base_bak]You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax …

.netcore 分布式事务CAP2.6 快速入门

CAP介绍&#xff1a;CAP是一个用来解决微服务或者分布式系统中分布式事务问题的一个开源项目解决方案。可以解决跨服务器的数据一致性问题。一个简单的列子&#xff0c;如&#xff1a;订单系统创建订单后需要通知邮件通知用户下单成功&#xff0c;解决方案有下面几种&#xff1…

[SDOI2017]数字表格

[SDOI2017]数字表格 假定n<m∏i1n∏j1mf(gcd(i,j))∏d1nf(d)∑i1n∑j1m[gcd(i,j)d]∏d1nf(d)∑i1nd∑j1md[gcd(i,j)1]∏d1nf(d)∑k1ndμ(k)nkdmkd由于nd具有分块性质&#xff0c;并且n&#xff0c;m不大&#xff0c;所以我们可以先预处理出斐波那契数列的前缀积&#xff0c;…