alibaba 字符串編程題

阿里內(nèi)推編程題.png

考點

  • 十六進制的字符串怎么處理?
    我們可以將其轉(zhuǎn)化成二進制的字符串處理(c++ 里先轉(zhuǎn)化成數(shù)字埠褪,在通過&1 取每一位浓利,來得到每一位,構(gòu)成字符串去操作), 或者轉(zhuǎn)化成一個數(shù)字,再去位操作钞速。

  • 位操作
    讓他匹配的關(guān)鍵是位操作&來取出需要的位贷掖,在通過異或^來判斷字符串與模式是否匹配

#include <iostream>
#include <vector>
#include <numeric>
#include<limits>
#include <sstream>
using namespace std;

/** 請完成下面這個函數(shù),實現(xiàn)題目要求的功能 **/
/** 當然渴语,你也可以不按照這個模板來作答苹威,完全按照自己的想法來 ^-^  **/

void deletePrefixZeros(string& str) {
    while (str.size() > 1 && str[0] == '0') {
        str.erase(0, 1);
    }
}

// check whether string has illegal char
bool isValid(string& str) {
    int length = (int)str.size();
    
    for(int i = 0; i < length; i++) {
        if( !((str[i] >= '0' && str[i] <= '9') || (str[i] >= 'A' && str[i] <= 'F'))) {
            return false;
        }
    }
    
    return true;
}

// empty string "" means input string illegal
string Decode(string in) {
    
    bool isLegal = isValid(in);
    if(!isLegal)
        return "";
    
    deletePrefixZeros(in);
    
    if (in.length() > 8) {
        return "";
    }
    
    int num = 0;
    stringstream ss;
    ss << hex << in;
    ss >> hex >> num;
    
    
    
    if( ((num & 0x80) ^ 0) == 0) {
        if(num >= 0 && num <= 127)
        {
            ss << num;
            string result;
            ss >> result;
            return result;
        }
        else{
            return "";
        }
    }
    else if( ((num & 0xE0C0) ^ 0xC080) == 0) {
        int trueNum = 0;
        num = num & 0x1F3F;
        
        trueNum += (num & 0xFF);
        num = num & 0xFF00;
        num = num >> 2;
        trueNum += num;
        
        stringstream sss;
        
        sss << trueNum;
        string result;
        sss >> result;
        return result;
    }
    else if( ((num & 0xF0C0C0) ^ 0xE08080) == 0) {
        // to do
    }
    else if( ((num & 0xF8C0C0C0) ^ 0xF0808080) == 0) {
       // to do
    }
    else
        return "";
    
    printf("haha");
    
    return "";
}

int main() {
    string res;
    
    string _in("C280");
    
    res = Decode(_in);
    cout << res << endl;
    
    return 0;
    
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市驾凶,隨后出現(xiàn)的幾起案子牙甫,更是在濱河造成了極大的恐慌,老刑警劉巖调违,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件窟哺,死亡現(xiàn)場離奇詭異,居然都是意外死亡技肩,警方通過查閱死者的電腦和手機且轨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來虚婿,“玉大人旋奢,你說我怎么就攤上這事∪蝗” “怎么了至朗?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長玷过。 經(jīng)常有香客問我爽丹,道長,這世上最難降的妖魔是什么辛蚊? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任粤蝎,我火速辦了婚禮,結(jié)果婚禮上袋马,老公的妹妹穿的比我還像新娘初澎。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布碑宴。 她就那樣靜靜地躺著软啼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪延柠。 梳的紋絲不亂的頭發(fā)上祸挪,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天,我揣著相機與錄音贞间,去河邊找鬼贿条。 笑死,一個胖子當著我的面吹牛增热,可吹牛的內(nèi)容都是我干的整以。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼峻仇,長吁一口氣:“原來是場噩夢啊……” “哼公黑!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起摄咆,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤蔬胯,失蹤者是張志新(化名)和其女友劉穎提针,沒想到半個月后辰狡,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體驹溃,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡含鳞,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年影锈,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蝉绷。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡鸭廷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出熔吗,到底是詐尸還是另有隱情辆床,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布桅狠,位于F島的核電站讼载,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏中跌。R本人自食惡果不足惜咨堤,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望漩符。 院中可真熱鬧一喘,春花似錦、人聲如沸嗜暴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至萎战,卻和暖如春咐容,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蚂维。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工疟丙, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鸟雏。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓享郊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親孝鹊。 傳聞我的和親對象是個殘疾皇子炊琉,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345

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

  • 在挖掘分析的過程當中對字符串的處理是極為重要的,且出現(xiàn)也較為頻繁又活,R語言作為當前最為流行的開源數(shù)據(jù)分析和可視化平臺...
    果果哥哥BBQ閱讀 5,793評論 0 8
  • 正則表達式到底是什么東西苔咪?字符是計算機軟件處理文字時最基本的單位,可能是字母柳骄,數(shù)字团赏,標點符號,空格耐薯,換行符舔清,漢字等...
    獅子挽歌閱讀 2,136評論 0 9
  • 很多人說愛情是一瞬的,但他們錯了曲初,愛情一旦發(fā)生就永遠不會消失体谒。 事情已經(jīng)發(fā)生,既然挽回不了臼婆,那么彼此承諾的相濡以沫...
    一只出圈的豬閱讀 194評論 0 1
  • 牛人是如何煉成的抒痒? 牛人之所以成為牛人,必有他們成功的秘訣颁褂,他們都非常的自律故响,我難以做到他們那樣,所以這就是差...
    紫翼天葵閱讀 198評論 0 0
  • 「教練颁独!我想打籃球」這個源于《灌籃高手》三井壽的著名臺詞彩届,現(xiàn)在天天被拿來用,以至于教練們都想回一句「你丫什么都想練...
    次元街閱讀 680評論 0 1