Problem Description
There must be many A + B problems in our HDOJ , now a new one is coming.
Give you two hexadecimal integers , your task is to calculate the sum of them,and print it in hexadecimal too.
Easy ? AC it !
Input
The input contains several test cases, please process to the end of the file.
Each case consists of two hexadecimal integers A and B in a line seperated by a blank.
The length of A and B is less than 15.
Output
For each test case,print the sum of A and B in hexadecimal in one line.
Sample Input
+A -A
+1A 12
1A -9
-1A -12
1A -AA
Sample Output
0
2C
11
-2C
-90
如果你对java很熟,那这一题是很easy的,方法可以在API中查找
package cn.hncu;
import java.util.Scanner;
public class J2057 {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
while(sc.hasNext()){
String str1=sc.next();
String str2=sc.next();
String s1=str1.replaceAll("\\+","");
//使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。
//调用此方法的 str.replaceAll(regex, repl) 形式与以下表达式产生的结果完全相同:
String s2=str2.replaceAll("\\+","");
long a=Long.parseLong(s1,16);
//将 string 参数解析为有符号的 long,基数由第二个参数指定。字符串中的字符必须为指定基数中的数字(由 Character.digit(char, int)
//是否返回一个非负值来确定),除非第一个字符为 ASCII 字符的减号 '-' ('\u002D'),它表示一个负值。返回得到的 long 值。
// 注意,不允许将字符 L ('\u004C') 和 l ('\u006C') 作为类型指示符出现在字符串的结尾处,
//而这一点在 Java 编程语言源代码中是允许的——除非 L 或 l 以大于 22 的基数形式出现。
long b=Long.parseLong(s2, 16);
long sum=a+b;
if(sum<0){
System.out.println("-"+Long.toHexString(-sum).toUpperCase());
}else{
System.out.println(Long.toHexString(sum).toUpperCase());
//使用默认语言环境的规则将此 String 中的所有字符都转换为大写。
}
}
}
}