整数转换为罗马数字

题目:

给定一个整数 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);*/

}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值