LCP9回文数[leetcode-9-easy]

LCP,9回文数

给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false

回文数

是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

  • 例如,121 是回文,而 123 不是。

回文可谓大学半桶水教育的常见题目,过去我也写过不少,但是怎么写的又快又好,是个问题
今天用升了级的方法论:双指针来写写

class Solution {
public:
    bool isPalindrome(int x) {
        //给算法加速:显然负数不是回文数
        if (x < 0) return false;
        /*
        其实分析可见更多
        边界条件:负数和以0结尾的数字(除了0本身)不是回文数
        
          if (x < 0 || (x % 10 == 0 && x != 0)) return false;
          但是,过长的边界往往会拖慢程序运行的速度
          这个语句的运行效率甚至不如简单的负数判断
          因为条件机构不符合CPU的流水线机构,会拖慢程序运行的速度(顺序和循环则不是)
          所以条件应尽可能简明,复杂边界往往适得其反
        */
        
        //对于字符串类的问题,或者可以转化为字符串的问题,to_string简直太好用
        string s = to_string(x);
        int l = 0;
        int r = s.length() - 1;//基数转换
        bool deleted = false; // 使用这个标记来记录是否使用了删除权限
        while (l <= r) {
            //如果有奇长度,则最后两个指针重合
            if (l == r)
                return true;
            //如果有偶数长度,则最后两个指针相邻
            if (s[l] == s[r]) {
                //保证指向的值相同
                if (l + 1 == r) return true;
                ++l;
                --r;
            }
            //注意不相等直接退出
            else return false;
        }
        return false;
    }
};

看看效果

可惜,不是100% ,不过这也可见双指针的威力之大。我23年其实写过这题一遍,当时傻乎乎的,用的vector存每位数字上的值,存完再对比,足足花了28ms,

在这里插入图片描述

  • 15
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值