题目描述:
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/biao-shi-shu-zhi-de-zi-fu-chuan-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
问题转换:
因为最近正在入门java,然后正好想起来之前力扣的这道题,就想起了可以用Java中的异常处理和类型转换另辟蹊径,将算法题改写成了语法题,虽然效率不高,但还是挺有趣的,所以分享一下
代码分析:
众所周知,Java中的包装类中都拥有将字符串转换成本类型的方法。parseXXX(),又因为题意可知,需要判断的是double类型和int类型,而int又可以自动转换为double直接赋值给double类型,当Double.parseDouble()执行时,底层调用FloatingDecimal.parseDouble(s),然后又调用readJavaFormatString(var0).doubleValue(),才对字符串进行处理。(以上请直接忽略)当然这次的解题方法不需要了解那么多。只需要会使用try{}catch{}基本语法。
1、首先,我们知道,当一个字符串无法转换成对应的数据类型,会抛出异常。因此,我们可以通过监测是否在转换时会抛出异常,就可以知道是否能转换成对应的类型。
2、在抛出异常后,我们可以断定不能转换成题目要求的类型,直接返回false.
3、但是,在对字符串进行转换时,会将数值后的标识数据类型的字母识别,认为是一个有效的数值。如:
11.11f
此时,通过Double.parseDouble(“11.11f”)能够成功转换成11.11的double类型数值。因为java机制认为这时一个合理的数值,而题目数据不这么认为。
通过测试,我们可以发现,测试数据并不会识别这个标识。所以这是一种特例,我们需要进行特判。
完整代码:
整个思路都在代码中写的十分详细,根据序号进行阅读
class Solution {
public boolean isNumber(String s) {
//通过try对异常进行监测
try{
//1.如果这里发生了异常,会直接被catch捕获,并且直接跳转到catch块中对异常进行处理,不会再继续执行发生异常后面的语句
double d = Double.parseDouble(s);
//3.如果转换成功,会继续执行try块中剩下的语句,
//那就还需要特判这个字符的尾部是否有f或者d等标识数值类型的字母,
//如果有,根据题意要求,不能算数值,所以直接返回false
//Character.isLetter(char)的作用就是判断一个字符是否为字母,是则返回true
if(Character.isLetter(s.charAt(s.length() - 1))) {
//这样我们就排除了这一种特殊情况
return false;
}
}catch(Exception e){
//2.如果发生异常,直接断定不能转换成字符,返回false
//因为如果能够符合转换成字符的条件,就可以正常转换,不会发生异常
return false;
}
//4.如果前面的所有情况都没有发生,那么就说明程序正常运行,数值转换成功且符合题意要求,则返回true
return true;
}
}
小结
虽然这种解题方式很菜,但是也是一种创新(偷懒),后序有时间会给出比较正确的题解。希望大家多多支持,有错误请多多指教。