leetcode-cn 回文數(shù)判斷

題目描述如圖:

回文數(shù)

解法基本分為兩類搜骡,一類是轉(zhuǎn)成字符數(shù)組,然后逐個(gè)比較左邊和右邊的字符密似,或者是轉(zhuǎn)成字符串秀撇,然后反轉(zhuǎn)燕酷,再進(jìn)行比較粮揉,其本質(zhì)都是單個(gè)字符的比較膊畴,大家都能想到织中,就不寫了锥涕。
另一類是直接對(duì)數(shù)字進(jìn)行操作,leetcode上有人例舉了狭吼,還不錯(cuò)层坠。我寫完之后,看別人的代碼刁笙,簡(jiǎn)潔好多破花,自嘆不如(不過(guò)我這個(gè)是支持負(fù)數(shù)回文數(shù)的??)直接貼代碼:

    private static boolean isPalindrome(int value) {
            // 除了 head 剩余有幾位
            int count = getCount(value);
            // 相當(dāng)于 2332 => number = 2000;
            int number = (int) Math.pow(10, count);
            for (; value > 9 || value < -9;) {
                // 第一位數(shù)
                int head = value / number;
                // 個(gè)位數(shù)
                int tail = value % 10;
                if (head != tail) {
                    return false;
                }
                // 去掉 head 和 tail 例如 2332 => 33
                count -= 2;
                value = (value - (number * head + tail)) / 10;
                int tmpCount = getCount(value);
                // head 之后有一個(gè)或多個(gè) 0 需要處理下
                if ((tmpCount = (count - tmpCount)) > 0 && value != 0) {
                    int pow = (int) Math.pow(10, tmpCount);
                    // 除了后 再往回乘 看是否相等
                    int tmp = value / pow;
                    if (tmp == 0 || value != tmp * pow) {
                        return false;
                    }
                    value = tmp;
                }
                // 更新
                count = getCount(value);
                number = (int) Math.pow(10, count);
            }
    
            return true;
        }
    
    private static int getCount(int value){
        int tmp = value;
        int count = 0;
        while (tmp > 9 || tmp < -9) {
            tmp /= 10;
            count++;
        }

        return count;
    }
回文數(shù)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市疲吸,隨后出現(xiàn)的幾起案子座每,更是在濱河造成了極大的恐慌,老刑警劉巖摘悴,帶你破解...
    沈念sama閱讀 218,284評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件峭梳,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蹂喻,警方通過(guò)查閱死者的電腦和手機(jī)葱椭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門捂寿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人孵运,你說(shuō)我怎么就攤上這事秦陋。” “怎么了治笨?”我有些...
    開封第一講書人閱讀 164,614評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵驳概,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我大磺,道長(zhǎng)抡句,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評(píng)論 1 293
  • 正文 為了忘掉前任杠愧,我火速辦了婚禮待榔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘流济。我一直安慰自己锐锣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評(píng)論 6 392
  • 文/花漫 我一把揭開白布绳瘟。 她就那樣靜靜地躺著雕憔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪糖声。 梳的紋絲不亂的頭發(fā)上斤彼,一...
    開封第一講書人閱讀 51,562評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音蘸泻,去河邊找鬼琉苇。 笑死,一個(gè)胖子當(dāng)著我的面吹牛悦施,可吹牛的內(nèi)容都是我干的并扇。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼抡诞,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼穷蛹!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起昼汗,我...
    開封第一講書人閱讀 39,223評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤肴熏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后乔遮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扮超,經(jīng)...
    沈念sama閱讀 45,668評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了出刷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片璧疗。...
    茶點(diǎn)故事閱讀 39,981評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖馁龟,靈堂內(nèi)的尸體忽然破棺而出崩侠,到底是詐尸還是另有隱情,我是刑警寧澤坷檩,帶...
    沈念sama閱讀 35,705評(píng)論 5 347
  • 正文 年R本政府宣布却音,位于F島的核電站,受9級(jí)特大地震影響矢炼,放射性物質(zhì)發(fā)生泄漏系瓢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評(píng)論 3 330
  • 文/蒙蒙 一句灌、第九天 我趴在偏房一處隱蔽的房頂上張望夷陋。 院中可真熱鬧,春花似錦胰锌、人聲如沸骗绕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)酬土。三九已至,卻和暖如春格带,著一層夾襖步出監(jiān)牢的瞬間撤缴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工叽唱, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留腹泌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,146評(píng)論 3 370
  • 正文 我出身青樓尔觉,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親芥吟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子侦铜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容