整数转换为罗马数字

2024-04-26 02:38
文章标签 转换 整数 罗马数字

本文主要是介绍整数转换为罗马数字,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:

给定一个整数 numnum,将整数转换成罗马数字。

如 1,2,3,4,51,2,3,4,5 对应的罗马数字分别为IIIIIIIVV等,更详细的说明见此 链接。

输入格式

第一行输入一个整数 num(1 \leq num \leq 3999)num(1num3999)

输出格式

输出 numnum 对应的罗马数字。

样例输入
123
样例输出

CXXIII

思路:发现其实整数的个位,十位,百位等上的数字的转为规则是一致的,只是表示的字符不一样,个位的一是I,十位则是X,那么这里我用了一个每一位的数字转换,需要传递四个参数,第一个是位上的数字,第二个是位上对应的1,第三个参数是位上对应的5,第四个参数是进位的对应的1.详细的函数:

public static String getStr(int num,String a,String b,String c){//a代表该位的1,b代表5
String cat = "";
         switch(num){
         case 1:
         case 2:
         case 3:
        for(int i=0;i<num;i++){
        cat+=a;
        }break;
         case 4:
        cat=a+b;break;
         case 5:
        cat=b;break;
         case 6:
         case 7:
         case 8:
        cat=b;
        for(int i=0;i<num-5;i++){
         cat+=a;
        }
        break;
         case 9:
        cat=cat+a+c;
        break;
         case 0:        
        break;     
         }


return cat;
}

接下来考虑到传参的便利,因为每一位上的数字都需要后面三个参数,那么个位对应的参数是I,V,X,十位对应的是X,L,C。用一个自定义类型来表示,然后用数组存储这个自定义类型会比较直观,方便。这里定义的是Domian类,名字起的不太好。Domain里面有三个成员变量a,b,c,对应上面的参数

最后就是转换的工作了,从高位到低位依次转换,并加入到一个总字符串,最终就可以得到结果。

关键函数:

public static String  convert(String number,Domain []d){
  int len=number.length();//字符串的长度
  String total="";
  for(int i=0;i<len;i++){
  String charAt=number.charAt(i)+"";
 String  a= d[len-i-1].getA();
 String b=d[len-i-1].getB();
 String c=d[len-i-1].getC();
 total=total+getStr(Integer.parseInt(charAt),a,b,c);
 
  }
  
  return total;
   }

完整代码:

import java.util.Scanner;


class Domain{
private String a;
private String b;
private String c;
public Domain(){

}
public Domain(String a, String b, String c) {
super();
this.a = a;
this.b = b;
this.c = c;
}
public String getA() {
return a;
}
public void setA(String a) {
this.a = a;
}
public String getB() {
return b;
}
public void setB(String b) {
this.b = b;
}
public String getC() {
return c;
}
public void setC(String c) {
this.c = c;
}


}
public class 整数转换为罗马数字 {
public static String getStr(int num,String a,String b,String c){//a代表该位的1,b代表5
String cat = "";
         switch(num){
         case 1:
         case 2:
         case 3:
        for(int i=0;i<num;i++){
        cat+=a;
        }break;
         case 4:
        cat=a+b;break;
         case 5:
        cat=b;break;
         case 6:
         case 7:
         case 8:
        cat=b;
        for(int i=0;i<num-5;i++){
         cat+=a;
        }
        break;
         case 9:
        cat=cat+a+c;
        break;
         case 0:        
        break;     
         }


return cat;
}
   public static String  convert(String number,Domain []d){
  int len=number.length();//字符串的长度
  String total="";
  for(int i=0;i<len;i++){
  String charAt=number.charAt(i)+"";
 String  a= d[len-i-1].getA();
 String b=d[len-i-1].getB();
 String c=d[len-i-1].getC();
 total=total+getStr(Integer.parseInt(charAt),a,b,c);
 
  }
  
  return total;
   }


   public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
String input=sc.nextLine();
Domain []d={new Domain("I","V","X"),new Domain("X","L","C"),new Domain("C","D","M"),
  new Domain("M","","")
  };
String result=convert(input, d);
System.out.println(result);


/*  String result= getStr(6,"I","v","x");
  System.out.println(result);*/
/*  
 for(int i=0;i<10;i++){
 String result= getStr(i,"I","v","x");
 System.out.println(result);
 }*/
/*   char a='a';
  String s=a+"";
  System.out.println(s);*/

}
}

这篇关于整数转换为罗马数字的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/936500

相关文章

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

数据流与Bitmap之间相互转换

把获得的数据流转换成一副图片(Bitmap) 其原理就是把获得倒的数据流序列化到内存中,然后经过加工,在把数据从内存中反序列化出来就行了。 难点就是在如何实现加工。因为Bitmap有一个专有的格式,我们常称这个格式为数据头。加工的过程就是要把这个数据头与我们之前获得的数据流合并起来。(也就是要把这个头加入到我们之前获得的数据流的前面)      那么这个头是

单精度浮点数按存储格式转为整数的程序

///#include<cstdio>//-----------------union int_char{unsigned char ch[4];float i;};void out_put(union int_char x)//x86是小端对其模式,即最数据的最低位存储在地址的最低位上。{printf("单精度浮点数值为:%f\n",x.i,x.i);printf("存储位置从左到右

高斯平面直角坐标讲解,以及地理坐标转换高斯平面直角坐标

高斯平面直角坐标系(Gauss-Krüger 坐标系)是基于 高斯-克吕格投影 的一种常见的平面坐标系统,主要用于地理信息系统 (GIS)、测绘和工程等领域。该坐标系将地球表面的经纬度(地理坐标)通过一种投影方式转换为平面直角坐标,以便在二维平面中进行距离、面积和角度的计算。 一 投影原理 高斯平面直角坐标系使用的是 高斯-克吕格投影(Gauss-Krüger Projection),这是 横

VC环境下整型转换为字符串型(2)

在串口下位机的发送中,可能会用到需要发送数字,显示为字符串型的 和上一篇文字《串口中字符串转换为整型》一正一反,知识点学习会了: #include<iostream.h> #include <stdio.h> #include <string.h>   void inttostr(int m,unsigned char * str) { int length=0;   int tmp,te

时间日期与时间戳转换(Linux C)

本文主要学习三个知识点,第一是UTC时间、GMT时间的概念;第二是在Unix环境下UTC时间与时间戳的转换;第三是在C语言中如何修改时区。 本文参考了《UNP》以及 http://blog.csdn.net/foxir/article/details/43916601 http://blog.csdn.net/ljafl9988/article/details/16847935 一、

点云数据常见的坐标系有哪些,如何进行转换?

文章目录 一、点云坐标系分类1. 世界坐标系2. 相机坐标系3. 极坐标系4. 笛卡尔坐标系(直角坐标系):5. 传感器坐标系6. 地理坐标系 二、坐标系转换方法1. 地理坐标系与投影坐标系之间的转换2. 投影坐标系与局部坐标系之间的转换3. 局部坐标系与3D模型坐标系之间的转换4. 相机坐标系与其他坐标系之间的转换5. 传感器坐标系与其他坐标系之间的转换 三、坐标系转换工具 一