麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統(tǒng) > iOS > 正文

詳細(xì)談?wù)刬OS字符串翻轉(zhuǎn)

2019-10-21 18:40:15
字體:
供稿:網(wǎng)友

前言

字符串翻轉(zhuǎn)作為算法題已經(jīng)是一個不能再基礎(chǔ)的問題了,無非就是逆序遍歷、雙指針遍歷、遞歸,代碼也能分分鐘寫出來:

void strrev(char *str) { size_t start = 0; size_t end = start + strlen(str) - 1; while (start < end) {  char ch = str[start];  str[start++] = str[end];  str[end--] = ch; }}

OK,上面的代碼放到 LeetCode 上絕對是能 AC 的,但是實際情況中能 AC 嗎?答案肯定是不能的!一個靠譜的字符串翻轉(zhuǎn)算法題放到 LeetCode 上至少是 Medium 的難度。

首先我們知道字符串有編碼規(guī)則,比如我們常用的 UTF-8,Windows 早期采用的 UTF-16(函數(shù)名有 W 后綴的 API 采用這種編碼)等等...對于英文字母等 ASCII 字符的情況,UTF-8 和 ASCII 編碼都是一個字節(jié),所以上述的方法沒有太大問題。然而對于有中文的情況,一個中文字符在 UTF-8 中會占 3 個字節(jié),如果單純的按字節(jié)翻轉(zhuǎn)就會出現(xiàn)亂碼。

那怎么解決呢?

最簡單的方法就是使用 mbstowcs 函數(shù)將 char * 類型的字符串轉(zhuǎn)換為 wchar_t 類型的寬字符串,wchar_t 這個類型在 Linux、UNIX 系統(tǒng)上占 4 個字節(jié),在 Windows 上占 2 個字節(jié)。4 個字節(jié)意味著字符將用 UTF-32 來編碼,不管是漢字還是 Emoji 都能存放下來。但對于 2 個字節(jié),也就是 UTF-16,漢字是能表示,但是 Emoji 這類位于輔助平面碼位的字符需要兩個碼元來表示,本文的方法就暫不適用了。

首先我們來看一下改進(jìn)版的字符串翻轉(zhuǎn):

static void strrev2(char *str) { setlocale(LC_CTYPE, "UTF-8"); size_t len = mbstowcs(NULL, str, 0); wchar_t *wcs = (wchar_t *) calloc(len + 1, sizeof(wchar_t)); mbstowcs(wcs, str, len + 1); size_t start = 0; size_t end = start + len - 1; while (start < end) {  wchar_t wc = wcs[start];  wcs[start++] = wcs[end];  wcs[end--] = wc; } wcstombs(str, wcs, wcstombs(NULL, wcs, 0)); free(wcs);}

使用 mbstowcs 這類轉(zhuǎn)換函數(shù)首先需要設(shè)置字符串的系統(tǒng)編碼,不然函數(shù)無法確定你傳入的 char * 是個什么東西,本文中不管是源碼還是系統(tǒng)環(huán)境的 std I/O 都采用 UTF-8 編碼。

接下來我們調(diào)用一次 mbstowcs 不傳入目標(biāo)地址和字符長度,這可以讓函數(shù)直接計算所需的 wchar_t 個數(shù)并返回回來以便我們申請內(nèi)存。

然后就是基于 wchar_t 的一個常規(guī)字符串翻轉(zhuǎn)了,最后別忘了轉(zhuǎn)換回去,釋放內(nèi)存即可。

Bonus: Cocoa 開發(fā)中的字符串翻轉(zhuǎn)

作為 iOS 開發(fā)者,當(dāng)然還要考慮 OC 中的解決方法了。

方案 1:

通過 API 遍歷子串,然后前向插入到新的 NSMutableString 中。

- (NSString *)my_stringByReversing { NSMutableString *reversed = [NSMutableString stringWithCapacity:self.length]; NSRange range = NSMakeRange(0, self.length); [self enumerateSubstringsInRange:range        options:NSStringEnumerationByComposedCharacterSequences       usingBlock:^(NSString * _Nullable substring, NSRange substringRange,          NSRange enclosingRange, BOOL * _Nonnull stop) {        [reversed insertString:substring atIndex:0];       }]; return [reversed copy];}

這種方法是效果最好的,它會將 Composed Emoji(如
注:相關(guān)教程知識閱讀請移步到IOS開發(fā)頻道。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产乱一区二区三区视频 | 国产精品成人亚洲一区二区 | 久久久成人999亚洲区美女 | 日韩欧美中文字幕视频 | 久久精品久 | 一级做a爰片性色毛片2021 | 国产精品久久久久久久久久了 | 久草最新在线 | 一区二区三区在线观看av | 视频国产一区二区 | 2017亚洲男人天堂 | 日韩视频在线观看免费视频 | 内地av在线 | 国产精品久久久久久久久久 | 久草在线视频精品 | 成人毛片免费 | 免费a级毛片永久免费 | 欧美特黄特色视频 | 成人免费激情视频 | 毛片a级毛片免费播放100 | 黑人日比视频 | 国产亚洲欧美在线视频 | 日韩视频一区在线 | 羞羞答答xxdd在线播放 | 午夜激情视频免费 | 国产69精品福利视频 | 色诱亚洲精品久久久久久 | 久久国产亚洲精品 | 精品一区二区三区在线观看视频 | 国产精品一区视频 | 99re热精品视频 | 在线播放污 | 亚洲视频精选 | 精品久久久久久亚洲精品 | jizzjizz中国少妇中文 | 1314av| 国产午夜精品久久久久婷 | 黄色一级片免费观看 | 精品国产乱码一区二区三区四区 | 全黄性性激高免费视频 | 久久久免费观看完整版 |