当前位置: 首页 > news >正文

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,

在这里插入图片描述


http://www.mrgr.cn/news/4545.html

相关文章:

  • vue面试题十七
  • 【原创】java+swing+mysql学生请假管理系统设计与实现
  • 小米便签——ui包详细解读
  • Unity3D URP 后处理如何作用于 UI 控件 Image 的详解
  • 大型语言模型(LLM)——直接偏好优化完整指南
  • 【Python爬虫】教你追剧看电影不求人!python爬虫代码教你爬取各平台视频,小白也能学会!附源码
  • 【Electron】桌面应用开发快速入门到打包Windows应用程序
  • hostapd生成beacon_ie
  • C语言破墙镐对称飞迷宫
  • 索引的数据结构
  • 《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 07数据中心的边缘
  • XSS game复现(DOM型)
  • Golang | Leetcode Golang题解之第354题俄罗斯套娃信封问题
  • 黑神话:悟空游戏用的什么服务器?
  • 构建艺术:Ruby中RESTful API的精粹实践
  • 【数据分析】时间滞后相干性分析
  • SSE请求多种实现方式总结
  • EmguCV学习笔记 C# 第5章 图像变换
  • k8s安装Metabase开源报表系统
  • P5594 【XR-4】模拟赛