Palindrome Number
程序员文章站
2022-03-15 20:36:17
...
题目:
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?
注意:判断是否是回文。
方法一:会超时
class Solution {
public:
bool isPalindrome(int x) {
if(x<0) return false;
int y,m=0;
int mm;
mm=x;
while(mm!=0)
{
y=mm%10;
mm=mm/10;
m=m*10+y;
}
if(m==x)
return true;
else
return false;
}
};
方法二:利用整和取余来判断,头取整,尾取余。整数取最后一位用整数本身和10取余,取第一位则用整数除以位数相同的10的n次方。
class Solution {
public:
bool isPalindrome(int x) {
if(x<0) return false;
int m=x;
int div=1;
while(m/div >= 10) div=div*10;
while(m>0)
{
int left=m/div;
int right=m%10;
if(left == right)
{
m=(m%div)/10;
div=div/100;
}
else return false;
}
return true;
}
};
方法三:折半的方法。首先将特殊情况给定,然后看前后半段是否相同。
class Solution {
public:
bool isPalindrome(int x) {
if(x<0 || x%10 == 0 && x!=0) return false;
int y=0;
while(x>y)
{
y=y*10+x%10;
x=x/10;
}
return x==y || x==y/10;
}
};
推荐阅读
-
【已解决】angularjs的select里option显示为<option value=“? number:xxx ?“ ></option>
-
mysql实现ROW_NUMBER() sql 排名
-
分页查询(用row_number()和开窗函数over()更方便)
-
FastCGI Error Error Number: 5 (0x80070005)解决办法_PHP教程
-
Oracle中纯数字的varchar2类型和number类型自动转换
-
PDO版本问题 Invalid parameter number: no parameters were bou
-
关于mysql error number 1051和1418错误的处理
-
Oracle row_number() over()解析函数高效实现分页_Oracle应用_脚
-
brew install npm >Error: [email protected]: wrong number of arguments (given 1, expected 0)
-
JS求Number类型数组中最大元素方法