C?C++?題解LeetCode1417重新格式化字符串
題目描述
題目鏈接:1417. 重新格式化字符串
給你一個(gè)混合了數(shù)字和字母的字符串 s
,其中的字母均為小寫(xiě)英文字母。
請(qǐng)你將該字符串重新格式化,使得任意兩個(gè)相鄰字符的類型都不同。也就是說(shuō),字母后面應(yīng)該跟著數(shù)字,而數(shù)字后面應(yīng)該跟著字母。
請(qǐng)你返回 重新格式化后 的字符串;如果無(wú)法按要求重新格式化,則返回一個(gè) 空字符串 。
提示:
- 1?s.length?5001
s
僅由小寫(xiě)英文字母和/或數(shù)字組成。
示例 1:
輸入:s = "a0b1c2"
輸出:"0a1b2c"
解釋:"0a1b2c" 中任意兩個(gè)相鄰字符的類型都不同。 "a0b1c2", "0a1b2c", "0c2a1b" 也是滿足題目要求的答案。
示例 2:
輸入: s = "leetcode"
輸出: ""
解釋: "leetcode" 中只有字母,所以無(wú)法滿足重新格式化的條件。
示例 3:
輸入: s = "1229857369"
輸出: ""
解釋: "1229857369" 中只有數(shù)字,所以無(wú)法滿足重新格式化的條件。
示例 4:
輸入: s = "covid2019"
輸出: "c2o0v1i9d"
示例 5:
輸入: s = "ab123"
輸出: "1a2b3"
整理題意
題目給定一個(gè)字符串,僅包含小寫(xiě)字母和數(shù)字,讓我們利用字符串中所給的這些字符構(gòu)造一個(gè)字符串,使得構(gòu)造出來(lái)的字符串中字母字符和數(shù)字字符不相鄰。答案返回任意一個(gè)滿足條件的字符串即可,如果無(wú)法構(gòu)造這樣的字符串返回空字符串。
解題思路分析
根據(jù)題目描述可知,為了使得字符串中不含有相鄰的字母和數(shù)字,我們盡可能的使得字母和數(shù)字交叉排列,那么當(dāng)字符串中數(shù)字個(gè)數(shù)和字母?jìng)€(gè)數(shù)的差值大于 1
時(shí),無(wú)論我們?cè)趺磁帕锌倳?huì)有兩個(gè)相同的字母字符或數(shù)字字符相鄰。
那么考慮當(dāng)字符串中數(shù)字個(gè)數(shù)和字母?jìng)€(gè)數(shù)的差值小于等于 1
時(shí),我們將個(gè)數(shù)較多的種類字符放在偶數(shù)位置上,較少的字符種類放在奇數(shù)位置上(位置從 0
開(kāi)始)。
具體實(shí)現(xiàn)
首先統(tǒng)計(jì)字符串中數(shù)字字符個(gè)數(shù)和字母字符個(gè)數(shù),并判斷兩者差值是否大于 1
,大于 1
的情況直接返回空字符串。
雙指針 實(shí)現(xiàn)字符串排列:
- 指針
i
指向偶數(shù)位置,j
指向奇數(shù)位置; - 初始化
i = 0
,j = 1
; - 當(dāng)
i
位置上的字符不為較多的字符種類時(shí),利用j
指針從左到右找到第一個(gè)較多的字符種類,與位置i
進(jìn)行交換字符; - 重復(fù)步驟
3
直至遍歷完整個(gè)字符串。
細(xì)節(jié)操作:代碼實(shí)現(xiàn)過(guò)程中僅用 if(isdigit(s[i]) != f)
這樣的判斷語(yǔ)句涵括了兩種情況的判斷。
復(fù)雜度分析
- 時(shí)間復(fù)雜度:O(n),其中
n
為字符串s
的長(zhǎng)度,需要遍歷兩遍字符串。 - 空間復(fù)雜度:O(1),僅使用常量空間。
代碼實(shí)現(xiàn)
class Solution { public: string reformat(string s) { // 統(tǒng)計(jì)數(shù)字和字母的個(gè)數(shù) int sum_digit = 0, sum_alpha = 0; for(auto &c : s){ if(isdigit(c)) sum_digit++; else sum_alpha++; } // 當(dāng)個(gè)數(shù)差大于 1 時(shí)無(wú)法構(gòu)造 if(abs(sum_digit - sum_alpha) > 1) return ""; bool f = sum_digit > sum_alpha; int n = s.size(); for(int i = 0, j = 1; i < n; i += 2){ // 注意判斷語(yǔ)句的難點(diǎn),和 f 有關(guān) if(isdigit(s[i]) != f){ while(isdigit(s[j]) != f) j += 2; swap(s[i], s[j]); } } return s; } };
總結(jié)
- 該題為簡(jiǎn)單的字符串題目,需要注意的是代碼實(shí)現(xiàn)過(guò)程中的判斷語(yǔ)句部分,
isdigit(s[i]) != f
這樣一句判斷語(yǔ)句即可涵括兩種情況的判斷,且判斷語(yǔ)句需要根據(jù)f
的定義來(lái)寫(xiě)。 - 另外就是雙指針的思想,巧妙利用雙指針實(shí)現(xiàn)字符串的原地構(gòu)造。
- 測(cè)試結(jié)果:
以上就是C C++ 題解LeetCode1417重新格式化字符串的詳細(xì)內(nèi)容,更多關(guān)于C C++ 重新格式化字符串的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C++ TensorflowLite模型驗(yàn)證的過(guò)程詳解
這篇文章給大家介紹了C++ TensorflowLite模型驗(yàn)證的過(guò)程,測(cè)試代碼,主要是RunInference()和read_file(),詳細(xì)操作過(guò)程跟隨小編一起看看吧2021-08-08C/C++ 原生API實(shí)現(xiàn)線程池的方法
線程池,簡(jiǎn)單來(lái)說(shuō)就是有一堆已經(jīng)創(chuàng)建好的線程,接下來(lái)通過(guò)本文給大家介紹C/C++ 原生API實(shí)現(xiàn)線程池的方法,感興趣的朋友跟隨小編一起看看吧2021-11-11C++ Leetcode實(shí)現(xiàn)從英文中重建數(shù)字
本文主要介紹了當(dāng)給你一個(gè)字符串s,其中包含字母順序打亂的用英文單詞表示的若干數(shù)字(0-9)時(shí),如何通過(guò)Leetcode按升序返回原始的數(shù)字。感興趣的童鞋可以來(lái)看看2021-11-11利用C++求解八數(shù)碼問(wèn)題實(shí)例代碼
所謂八數(shù)碼問(wèn)題是指這樣一種游戲,將分別標(biāo)有數(shù)字1,2,3,…,8的八塊正方形數(shù)碼牌任意地放在一塊3×3的數(shù)碼盤(pán)上,放牌時(shí)要求不能重疊,下面這篇文章主要給大家介紹了關(guān)于利用C++求解八數(shù)碼問(wèn)題的相關(guān)資料,需要的朋友可以參考下2022-11-11exec()函數(shù)在C++中的應(yīng)用及其用法
exec()函數(shù)在C++中是一個(gè)進(jìn)程控制函數(shù),用于創(chuàng)建新進(jìn)程執(zhí)行其他程序或命令行指令。exec()函數(shù)可以替換當(dāng)前進(jìn)程的代碼和數(shù)據(jù),創(chuàng)建新的進(jìn)程運(yùn)行其他程序。exec()函數(shù)有多個(gè)版本,例如execl、execv、execle、execve等,根據(jù)不同的參數(shù)類型和個(gè)數(shù)來(lái)使用2023-05-05