广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++怎么实现验证回文数字
  • 712
分享到

C++怎么实现验证回文数字

2023-06-19 12:06:02 712人浏览 独家记忆
摘要

本篇内容介绍了“c++怎么实现验证回文数字”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Palindrome Number 验证回文数字De

本篇内容介绍了“c++怎么实现验证回文数字”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

Palindrome Number 验证回文数字

Determine whether an integer is a palindrome. An integer is a palindrome when it reads the same backward as forward.

Example 1:

Input: 121
Output: true

Example 2:

Input: -121
Output: false
Explanation: From left to right, it reads -121. From right to left, it becomes 121-. Therefore it is not a palindrome.

Example 3:

Input: 10
Output: false
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.

Follow up:

Coud you solve it without converting the integer to a string?

这道验证回文数字的题如果将数字转为字符串,就变成了验证回文字符串的题,没啥难度了,我们就直接来做 follow up 吧,不能转为字符串,而是直接对整数进行操作,可以利用取整和取余来获得想要的数字,比如 1221 这个数字,如果 计算 1221 / 1000, 则可得首位1, 如果 1221 % 10, 则可得到末尾1,进行比较,然后把中间的 22 取出继续比较。代码如下:

解法一:

class Solution {public:    bool isPalindrome(int x) {        if (x < 0) return false;        int div = 1;        while (x / div >= 10) div *= 10;        while (x > 0) {            int left = x / div;            int right = x % 10;            if (left != right) return false;            x = (x % div) / 10;            div /= 100;        }        return true;    }};

再来看一种很巧妙的解法,还是首先判断x是否为负数,这里可以用一个小 trick,因为整数的最高位不能是0,所以回文数的最低位也不能为0,数字0除外,所以如果发现某个正数的末尾是0了,也直接返回 false 即可。好,下面来看具体解法,要验证回文数,那么就需要看前后半段是否对称,如果把后半段翻转一下,就看和前半段是否相等就行了。所以做法就是取出后半段数字,进行翻转,具体做法是,每次通过对 10 取余,取出最低位的数字,然后加到取出数的末尾,就是将 revertNum 乘以 10,再加上这个余数,这样翻转也就同时完成了,每取一个最低位数字,x都要自除以 10。这样当 revertNum 大于等于x的时候循环停止。由于回文数的位数可奇可偶,如果是偶数的话,那么 revertNum 就应该和x相等了;如果是奇数的话,那么最中间的数字就在 revertNum 的最低位上了,除以 10 以后应该和x是相等的,参见代码如下:

解法二:

class Solution {public:    bool isPalindrome(int x) {        if (x < 0 || (x % 10 == 0 && x != 0)) return false;        int revertNum = 0;        while (x > revertNum) {            revertNum = revertNum * 10 + x % 10;            x /= 10;        }        return x == revertNum || x == revertNum / 10;    }};

“C++怎么实现验证回文数字”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: C++怎么实现验证回文数字

本文链接: https://www.lsjlt.com/news/296201.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++怎么实现验证回文数字
    本篇内容介绍了“C++怎么实现验证回文数字”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Palindrome Number 验证回文数字De...
    99+
    2023-06-19
  • C++实现LeetCode(9.验证回文数字)
    [LeetCode] 9. Palindrome Number 验证回文数字 Determine whether an integer is a palindrome. An int...
    99+
    2022-11-12
  • C++怎么实现验证数字
    本篇内容介绍了“C++怎么实现验证数字”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Valid Number 验证数字Validate if...
    99+
    2023-06-19
  • C++实现LeetCode(125.验证回文字符串)
    [LeetCode] 125.Valid Palindrome 验证回文字符串 Given a string, determine if it is a palindrome, co...
    99+
    2022-11-12
  • C++实现LeetCode(65.验证数字)
    [LeetCode] 65.Valid Number 验证数字 Validate if a given string can be interpreted as a dec...
    99+
    2022-11-12
  • 怎么使用C++验证数字
    这篇文章主要讲解了“怎么使用C++验证数字”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用C++验证数字”吧!首先,从题目中给的一些例子可以分析出来,...
    99+
    2022-10-19
  • php怎么实现数字验证码
    本文操作环境:windows7系统、PHP7.1版、DELL G3电脑php怎么实现数字验证码?php实现数字验证码用php实现验证码,验证码是为了区别机器与人的操作,提高安全性。需要安装服务器软件,我使用的是wamp,之后编写php验证码...
    99+
    2014-09-23
    php
  • C++中怎么实现回文
    C++中怎么实现回文,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。下面是C++回文的判定算法:#include < iostream> ...
    99+
    2023-06-17
  • C++实现LeetCode(36.验证数独)
    [LeetCode] 36. Valid Sudoku 验证数独 Determine if a 9x9 Sudoku board is valid. O...
    99+
    2022-11-12
  • jquery如何实现验证数字
    本篇内容主要讲解“jquery如何实现验证数字”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“jquery如何实现验证数字”吧! 方法...
    99+
    2022-10-19
  • PHP怎么实现随机数字、字母的验证码功能
    本篇内容主要讲解“PHP怎么实现随机数字、字母的验证码功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP怎么实现随机数字、字母的验证码功能”吧!废话不多说,直接上代码:1、classgd....
    99+
    2023-06-04
  • C++实现验证数独的方法
    本篇内容主要讲解“C++实现验证数独的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++实现验证数独的方法”吧!Valid Sudoku 验证数独Determine if a 9...
    99+
    2023-06-20
  • 怎么用Java实现添加、验证PDF数字签名
    这篇文章主要讲解了“怎么用Java实现添加、验证PDF数字签名”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Java实现添加、验证PDF数字签名”吧!目录Jar文件获取及导入方法:在设...
    99+
    2023-06-20
  • Nginx如何实现直接返回验证文件
    这篇文章给大家分享的是有关Nginx如何实现直接返回验证文件的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。直接返回验证文件location = /XDFyle...
    99+
    2022-10-19
  • C++如何实现回文子字符串
    这篇文章主要介绍“C++如何实现回文子字符串”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++如何实现回文子字符串”文章能帮助大家解决问题。Palindromic Substrings 回文子字符...
    99+
    2023-06-19
  • C++实现LeetCode(647.回文子字符串)
    [LeetCode] 647. Palindromic Substrings 回文子字符串 Given a string, your task is to count how man...
    99+
    2022-11-12
  • Blazor怎么实现数据验证
    本文小编为大家详细介绍“Blazor怎么实现数据验证”,内容详细,步骤清晰,细节处理妥当,希望这篇“Blazor怎么实现数据验证”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Blazor 提供一组输入组件。 输入...
    99+
    2023-06-29
  • Python实现验证回文串的方法有哪些
    这篇文章主要介绍了Python实现"验证回文串"的方法有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。python可以做什么Python是一种编程语言...
    99+
    2023-06-14
  • Python实现"验证回文串"的几种方法
    一、LeetCode——125.验证回文串 1.问题描述 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。 说明:本题中,我们将空字符串定义为有效的...
    99+
    2022-11-12
  • 怎么用JS验证逗号隔开可以是中文字母数字
    本文小编为大家详细介绍“怎么用JS验证逗号隔开可以是中文字母数字”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用JS验证逗号隔开可以是中文字母数字”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。具体代码如下所...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作