题解 | #牛的回文编号II#

牛的回文编号II

https://www.nowcoder.com/practice/0b576fd673834425878b99c736bb6c34

知识点:双指针,字符串

首先要将整数部分和小数部分分割开来,分别进行判断,对于小数部分,我们还要删除末尾的零,处理完成后,要对两个字符串进行回文串判断,具体来说,使用双指针指向字符串两侧,若指向字符相同,则向内靠拢,直至重叠,说明是回文字符串,否则不是。

Java题解如下

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param x string字符串 
     * @return bool布尔型
     */
    public boolean isPalindromeNumber (String x) {
        // write code here
        String digit1 = x.substring(0, x.indexOf("."));
        String digit2 = x.substring(x.indexOf(".") + 1, x.length());
        int index = digit2.length() - 1;
        while(digit2.charAt(index) == '0') {
            index--;
        }
        digit2 = digit2.substring(0, index + 1);
        if(!checkStr(digit1) || !checkStr(digit2)) {
            return false;
        }
        return true;
    }

    private boolean checkZero(String s) {
        for(int i = 0; i < s.length(); i++) {
            if(s.charAt(i) != '0') {
                return false;
            }
        }
        return true;
    }

    private boolean checkStr(String s) {
        int n = s.length();
        for(int i = 0; i < n / 2; i++) {
            if(s.charAt(i) != s.charAt(n - 1 - i)) {
                return false;
            }
        }
        return true;
    }
}

全部评论

相关推荐

xdm怎么说&nbsp;要被拷打了&nbsp;担心是KPI
丹田:面就完了,就当日薪四位数的大佬免费给给你面试。
点赞 评论 收藏
分享
05-05 21:45
已编辑
广州大学 Java
点赞 评论 收藏
分享
uu们,拒offer时hr很生气怎么办我哭死
爱睡觉的冰箱哥:人家回收你的offer,或者oc后没给你发offer的时候可不会愧疚你,所以你拒了也没必要愧疚他。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务