问题
判定一个正整数是否是一个回文数。例如12121是回文数,而1231不是回文数。
解法1:转换成字符串再判断
要判断一个整数是否是回文数,最自然的想法是把整数转换成一个字符串,然后根据回文的对称特性进行判断。数字转换为字符串可以通过itoa函数实现,判断字符串是否为回文字符串代码如下:
bool isPalindrome(string &str)
{
int begin = 0, end = str.length()-1;
while (begin < end) {
if (str[begin] == str[end]) {
begin++;
end--;
} else {
return false;
}
}
return true;
}
解法2:数字翻转法
因为是整数,所以可以求出该整数的翻转后的数值,看是否与原来整数相等。如果相等,则是回文数,否则不是。翻转整数代码如下,返回值为翻转后的整数。如12321翻转后为12321,所以是回文数;而1231翻转后为1321,与1231不相等,所以不是回文数。
int reverse(int num)
{
assert(num >= 0);
int rev = 0;
while (num != 0) {
rev = rev * 10 + num % 10;
num /= 10;
}
return rev;
}
但是这里有个潜在的问题就是翻转后的整数可能会溢出,当然我们可以用long long之类的类型来保存翻转结果。但是这个解法总的来看并不完美,我们需要找一个更通用的解法。
解法3:数字位判断法
我们可以找到一个更通用的解法,那就是先比较整数的第1位和最后1位是否相等,如果不等,则直接返回false;若相等,则接下去判断剩下的位置,如同回文字符串判断的过程一样。代码如下:
bool isPalindrome(int x)
{
if (x < 0) return false;
int div = 1;
while (x / div >= 10) {
div *= 10;
}
while (x != 0) {
int l = x / div;
int r = x % 10;
if (l != r) return false;
x = (x % div) / 10;
div /= 100;
}
return true;
}
如整数为121,则div初始会设为100,因此l=21/100=1是整数的第1位,而r=121%10=1是最后1位。这两位相等,则继续循环,设置x为第2为2,此时div除以100变成1,之所以div除以100是因为每次比较了两个位。
分享到:
相关推荐
在Python编程中,判断一个整数是否为回文数是一个常见的任务。回文数是指从左到右和从右到左读都一样的数,例如121、12321等。以下介绍两种方法来实现这个功能: 方法一:逐位判断 这种方法通过循环逐个比较数字的...
1.判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。 示例 1: 输入: 121 输出: true 示例 2: 输入: -121 输出: false 解释: 从左向右读, 为 -121 。 从右向左读, 为 121- ...
本节将详细介绍如何使用C#编程语言来检测一个整数是否为回文数。我们将通过一个具体的例子来进行讲解,包括代码的逻辑和工作原理。 #### 三、代码解析 ##### 1. **IsPalindrome 方法** 该方法用于判断给定的整数 ...
输入一个5位整数,判断该数是否是一个回文。例如12521是一个回文,将其按相反的顺序排列,仍然是12521
判断一个数是否为回文数,我们可以将其转换为字符串,然后比较其首尾字符,再逐步向中间移动,直至比较完所有字符。如果在任何时候发现字符不匹配,则该数不是回文数。 现在,我们来讨论如何判断一个整数是几位数。...
js代码-判断一个整数是否是回文数。 回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。 示例 1: 输入: 121 输出: true 示例 2: 输入: -121 输出: false 解释: 从左向右读, 为 -121 ...
【问题描述】输入一个整数,判断其是否为回文数!回文数是不论从左向右顺读,还是从右向左倒读,结果都是一样的,例如151,15351. 【输入形式】从键盘输入一个整数 【输出形式】判断其是否回文数 【样例输入】 151 ...
def hwnum(n): m=n[::-1] if (m==n): print("是回文数字。") else: print("不是回文数字。") num=input("请输入你要查询的回文数字:") hwnum(num)
在Java中,判断一个整数是否为回文数字是一项常见的任务,常用于各种算法问题。下面我们将详细介绍如何用Java来实现这个功能。 首先,我们可以采用将数字转化为字符串然后比较其正读与反读的方法。这种方法简单易懂...
在C语言中,编写一个函数来判断一个整数是否为回文数是一项常见的编程练习,它可以帮助初学者更好地理解数字处理和字符串操作。回文数是一个可以正向和反向读取都相同的数字,比如12321、111、45654等。下面我们将...
在Java编程中,判断一个数字是否为回文是常见的基础算法问题,这通常涉及到字符串处理和循环结构。下面我们将深入探讨如何用Java实现回文数字的判断。 首先,我们可以将数字转换为字符串,这是因为数字的正反序比较...
用户从键盘输入一个1-9999之间的数,程序将判断这个数是几位数,并判断这个数是否回文数。回文数是指将数含有的数字逆序排列后得到的数和原数相同,例如12121,4224,6778776等都是回文数。 1)程序具有判断用户的输入...
在计算机科学与编程领域,判断一个数是否为回文数是一个常见的练习题目。回文数是指正读反读都一样的数字,如121、3443等。这类问题不仅能够帮助初学者熟悉基本的数据处理流程,还能够锻炼其逻辑思维能力。 #### ...
"""判断一个整数是否是回文数""" return str(num) == str(num)[::-1] def main_game(): print("欢迎来到《回文迷宫》!") level = 1 while True: print(f"当前关卡:{level}") num = input("请输入...
首先,我们需要理解如何判断一个数是否为回文数。一种简单的方法是将数字转换为字符串,然后比较字符串的前半部分与后半部分是否相同。如果相同,那么这个数就是回文数。C语言中,可以使用`itoa()`函数将整数转换为...
判断一个数是否为回文数,通常涉及到数值处理、字符串操作等方面的知识。 #### 三、回文数的判断方法 ##### 1. 数学方法 - **步骤一:** 获取用户输入的整数。 - **步骤二:** 确定该数的位数。 - **步骤三:** ...
在编程领域,回文数是一个重要的概念,它指的是无论从左向右还是从右向左读都一样的数,比如121或者12321。在Python中,判断一个整数是否为回文数可以通过多种方法实现。下面我们将详细讨论两种常见的Python算法。 ...
# 判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数 # 示例 1: # 输入: 121 # 输出: true # 示例 2: # 输入: -121 # 输出: false # 解释: 从左向右读, 为 -121 。 从右向...
输入一个整数判断其是否是回文数……可以直接在vc6.0平台上 直接运行通过,例如输入 121 ,则输出,恭喜您,您输入的是回文数……呵呵,见笑了,学习学习……