题目描述:
给定一个数,请将该数各个位上数字反转得到一个新数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。
整数反转是将所有数位对调。
小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分。
分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。
百分数的分子一定是整数,百分数只改变数字部分。
输入格式
一个数 sss
输出格式
一个数,即 sss 的反转数
输入输出样例
输入 #1
5087462
输出 #1
2647805
输入 #2
600.084
输出 #2
6.48
输入 #3
700/27
输出 #3
7/72
输入 #4
8670%
输出 #4
768%
说明/提示
所有数据:25%s是整数,不大于20位
25%s是小数,整数部分和小数部分均不大于10位
25%s是分数,分子和分母均不大于10位
25%s是百分数,分子不大于19位
(20个数据)
数据保证:
对于整数翻转而言,整数原数和整数新数满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数和原来的数字的最高位数字不应为零。
对于小数翻转而言,其小数点前面部分同上,小数点后面部分的形式,保证满足小数的常见形式,也就是末尾没有多余的 000(小数部分除了 000 没有别的数,那么只保留 111 个 000。若反转之后末尾数字出现 000,请省略多余的 000)
对于分数翻转而言,分数不约分,分子和分母都不是小数。输入的分母不为0。与整数翻转相关规定见上。
对于百分数翻转而言,见与整数翻转相关内容。
数据不存在负数。
解法:
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class Main {
public static void main(String args[]) throws Exception {
BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
String line = bf.readLine();
String res = "";
if (line.indexOf('.') != -1) {
int idx = line.indexOf('.');
String temp = reverse(line.substring(0, idx)) + "." + reverse(line.substring(idx + 1));
int end = temp.length() - 1;
while (temp.charAt(end) == '0') {
end--;
}
res = temp.substring(0, end + 1);
if(res.charAt(res.length()-1) == '.'){
res = res + 0;
}
} else if (line.indexOf('/') != -1) {
int idx = line.indexOf('/');
int end = line.length() - 1;
while (line.charAt(end) == '0') {
end--;
}
res = reverse(line.substring(0, idx)) + "/" + reverse(line.substring(idx + 1,end+1));
} else if (line.charAt(line.length() - 1) == '%') {
res = reverse(line.substring(0, line.length() - 1)) + "%";
} else {
res = reverse(line);
}
int start = 0;
while (start < res.length()&&res.charAt(start) == '0' ) {
start++;
}
String sub = res.substring(start);
if(sub.equals("")||sub.charAt(0) =='.'||sub.charAt(0) == '%'||sub.charAt(0) == '/'){
System.out.println(0+sub);
}else {
System.out.println(sub);
}
}
private static String reverse(String str) {
StringBuilder sb = new StringBuilder(str);
return sb.reverse().toString();
}
}
思路概述:
分别判断是否是小数、分数、百分数,都不是直接反转,把前置位的0去掉
如果是小数:整数部分前置位的0去掉,分数部分后置位的0去掉。如果某位置只有0,则补一个0
如果是分数:分子、分母前置位的0都要去掉,分母如果只有0,则补一个0
如果是百分数:数字部分前置位的0去掉,如果只有0,则补一个0.
埋坑位置:
0
1.000
0.01
00/2
0%
之类,要注意去掉0之后,该补0的情况