LeetCode刷题 题9. 回文数

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

回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121 是回文,而 123 不是。
示例 2:

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

思路:使用字符串来进行处理。
函数string s = to_string(x)是将数值x转化为字符串s,reverse(s1.begin(), s1.end()); //是对s进行反转,比如s1 = “123456”,则反转之后s1 = “654321”;将s 与s1 进行比较,看是否相等。

补充知识点:
to_string(x) 是将数值x转化为字符串的函数
reverse(s.begin(), s.end()); 是对字符串进行反转的函数。

bool isPalindrome(int x) {
        string s = to_string(x);   //将数值x转换为字符串s
        string s1 = s;    // 令s1 = s
        reverse(s1.begin(), s1.end());  //对s1进行反转。
        if(s1 == s)
            return true;    //若s1 == s,则证明反转之后是一样的,就是回文数。
        return false;
    }

思路二:采用数组来处理。
首先对于x小于0的情况,直接返回false
然后把x以逆序的方式存储到数组中,然后再求出数组的值,来与x进行比较,看是否相等。
比如:x = 1234543,则存入数组中为a[] = {3, 4, 5, 4, 3, 2, 1},再对a[]中求出数值res为3454321与x进行比较,看是否相等。注意res的类型要用long,因为若x=1234567899,那么用int类型就会溢出。

bool isPalindrome(int x) {
        if(x < 0)    //针对x<0的情况
            return false;
        int x1 = x;
        vector a;
        while(x1){
            a.push_back(x1%10);
            x1 /= 10;
        }   //把x以逆序的方式存储到数组中,比如x=1234543
        int len = a.size();
        long res = 0;  //用long是怕溢出,比如x=1234567899是没有溢出,但是9987654321就不能存储在int类型中。
        for(int i=0; i

你可能感兴趣的:(LeetCode刷题 题9. 回文数)