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

L8.【LeetCode笔记】回文数

1.题目

https://leetcode.cn/problems/palindrome-number/description/

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

回文数

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

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

示例 1:

输入:x = 121
输出:true

示例 2:

输入:x = -121
输出:false
解释:从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。

示例 3:

输入:x = 10
输出:false
解释:从右向左读, 为 01 。因此它不是一个回文数。

提示:

  • -231 <= x <= 231 - 1

进阶:你能不将整数转为字符串来解决这个问题吗?

2.自解

由题可知:

1.负数不是回文数

2.判断回文数的算法:

1.如果不将整数转为字符串

分别取出回文数的每个位,再乘以10的次方

如121%10==1;12%10=2;1%10=1-->1*100+2*10+1*1==121;121==121,为回文数

143%10==3;14%10=4;1%10=1-->3*100+4*10+1*1==341,341!=143,不为回文数

2.如果将整数转为字符串

双指针访问

方法1:不将整数转为字符串

代码

bool isPalindrome(int x) 
{if (x<0)return false;if (x==0)return true;int save_x=x;int save_x_=x;int length=0;int sum=0;while (x){x/=10;length++;}while (save_x){sum+=(save_x%10)*pow(10,length-1);save_x/=10;length--;}if (sum==save_x_)return true;elsereturn false;
}

运行结果

方法2:将整数转为字符串+双指针访问

代码

bool isPalindrome(int x)
{if (x < 0)return false;if (x==0)return true;char arr[11] = { 0 };int length = 0;char* left = NULL;char* right = NULL;while (x){arr[length] = x % 10;x /= 10;length++;}left = &arr[0];right = &arr[length-1];while (left < right){if (*left == *right){left++;right--;continue;}elsereturn false;}return true;}

注:&arr[length-1]的另一种写法&(*(arr+length-1))

运行结果

http://www.lryc.cn/news/480997.html

相关文章:

  • 双版本android studio安装
  • npm镜像的常用操作
  • Unity插件NodeCanvas之行为树的详细教程
  • Vue全栈开发旅游网项目(9)-用户登录/注册及主页页面开发
  • Flutter 的 Widget 概述与常用 Widgets 与鸿蒙 Next 的对比
  • 微服务day04
  • Spring Boot 集成JWT实现Token验证详解
  • 如何快速搭建一个spring boot项目
  • 学习笔记:黑马程序员JavaWeb开发教程(2024.11.9)
  • 【软考】系统分析师第二版 新增章节 第20章微服务系统分析与设计
  • 抓包工具WireShark使用记录
  • C++上机实验|多态性编程练习
  • php伪协议介绍
  • 『事善能』MySQL基础 — 2.MySQL 5.7安装(一)
  • 漫谈分布式唯一ID
  • 【复旦微FM33 MCU 开发指南】ADC
  • ORB_SLAM3安装
  • GoLang协程Goroutiney原理与GMP模型详解
  • 全文检索ElasticSearch到底是什么?
  • FPGA实现串口升级及MultiBoot(五)通过约束脚本添加IPROG实例
  • 文献阅读 | Nature Methods:使用 STAMP 对空间转录组进行可解释的空间感知降维
  • 【模块化大作战】Webpack如何搞定CommonJS与ES6混战(1-3)
  • [NewStar 2024] week5完结
  • IntelliJ IDEA的快捷键
  • 暮雨直播 1.3.2 | 内置直播源,频道丰富,永久免费
  • 单相锁相环,原理与Matlab实现
  • PICO+Unity 用手柄点击UI界面
  • Rust移动开发:Rust在iOS端集成使用介绍
  • 虚拟现实技术在旅游行业的应用
  • 《Java核心技术 卷I》Swing使用颜色