go語言快速刷《程序員面試金典》(1)

實現一個算法,確定一個字符串 s 的所有字符是否全都不同。

一個數組統計是否有

func isUnique(astr string) bool {var arr[26] int;for _,ch:=range astr{num:=ch-'a'if(arr[num]==1){return false}arr[num]++}return true
}

給定兩個字符串 s1 和 s2,請編寫一個程序,確定其中一個字符串的字符重新排列后,能否變成另一個字符串。

記錄字符出現的個數,對比即可。

func CheckPermutation(s1 string, s2 string) bool {var arr[26] int;var brr[26] int;for _,ch:=range s1{arr[ch-'a']++;}for _,ch:=range s2{brr[ch-'a']++;}for i:=0;i<26;i++{if(arr[i]!=brr[i]){return false;}}return true;
}

URL化。編寫一種方法,將字符串中的空格全部替換為%20。假定該字符串尾部有足夠的空間存放新增字符,并且知道字符串的“真實”長度。(注:用Java實現的話,請使用字符數組實現,以便直接在數組上操作。)

?

func replaceSpaces(S string, length int) string {return strings.ReplaceAll(S[:length], " ", "%20")
}

注意第8行是個坑。動態length不能用注釋中的方式初始化數組。

func replaceSpaces(S string, length int) string {num := 0for i:=0;i <length; i++ {if S[i] == ' ' {num++}}//var result[2*num + length] byte;result := make([]byte, 3*num + (length-num))k := 0for i:=0;i <length; i++ {if S[i] == ' ' {result[k] = '%'result[k+1] = '2'result[k+2] = '0'k += 3} else {result[k] = S[i]k++}}return string(result)
}

給定一個字符串,編寫一個函數判定其是否為某個回文串的排列之一。

回文串是指正反兩個方向都一樣的單詞或短語。排列是指字母的重新排列。

回文串不一定是字典當中的單詞。

?

示例:

輸入:"tactcoa"
輸出:true(排列有"tacocat"、"atcocta",等等)

思路:至多有一個字符出現過奇數次。

func canPermutePalindrome(s string) bool {var arr[128] int;for _,ch:=range s{arr[ch]++;}num:=0for _,i:=range arr{num+=i%2;}return num<=1;
}

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/444053.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/444053.shtml
英文地址,請注明出處:http://en.pswp.cn/news/444053.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

最小生成樹【數據結構】

前提 【1】網的最小生成樹&#xff0c;涉及到生成樹了那么就會有最小的權值在里面了 【2】對于一個圖來說生成樹是由多個的&#xff0c;并不是唯一的 【3】&#xff1a;廣度優先算法的遍歷是可以得到生成樹的&#xff0c;深度優先算法也是可以得到生成樹的 任意的一個聯通網&am…

go語言快速刷《程序員面試金典》(2)

字符串輪轉。給定兩個字符串s1和s2&#xff0c;請編寫代碼檢查s2是否為s1旋轉而成&#xff08;比如&#xff0c;waterbottle是erbottlewat旋轉后的字符串&#xff09;。 示例1 輸入&#xff1a;s1 "waterbottle", s2 "erbottlewat" 輸出&#xff1a;T…

廣義表的基本概念【數據結構】

實名廣義表與匿名廣義表的區別&#xff1a;對于匿名的廣義表的表示方法我們認為一對括號就是一個廣義表&#xff0c;里面的數據可以是廣義表也可以是 原子&#xff0c;對于有名字的廣義表&#xff0c;也就是大寫的字母我們可以直接認為大寫的就是廣義表的表示方法小練習----廣義…

go語言快速刷《程序員面試金典》(3)

編寫程序以 x 為基準分割鏈表&#xff0c;使得所有小于 x 的節點排在大于或等于 x 的節點之前。如果鏈表中包含 x&#xff0c;x 只需出現在小于 x 的元素之后(如下所示)。分割元素 x 只需處于“右半部分”即可&#xff0c;其不需要被置于左右兩部分之間。 示例: 輸入: head …

樹和二叉樹【數據結構】

基本概念 ADT的定義 基本操作 對比樹形結構和線性結構 基本術語以及注意事項-不能錯誤簡單的我以為 二叉樹是度數小于等于2的樹&#xff0c;而不是度為2的樹&#xff0c;一定要記住這個概念 小知識&#xff1a;二進制轉換成為十進制的方法名稱叫做位權求和法&#xff0c;用到…

leetcode557. 反轉字符串中的單詞 III python,處理字符串的神!

給定一個字符串&#xff0c;你需要反轉字符串中每個單詞的字符順序&#xff0c;同時仍保留空格和單詞的初始順序。 示例 1: 輸入: "Lets take LeetCode contest" 輸出: "steL ekat edoCteeL tsetnoc" 注意&#xff1a;在字符串中&#xff0c;每個單詞由…

數據庫2.1.1mysql的特點

在mysql5.1當中&#xff0c;mysqlab公司引入了新的插件式存儲引擎體系結構&#xff0c;也許將存儲引擎加載到正在運行的mysql服務器當中&#xff0c;使用mysql插件是存儲引擎體系結構允許數據庫用戶為特定的應用需求選擇專門的存儲引擎&#xff0c;完全不需要管理任何特殊的應用…

leetcode369. 給單鏈表加一

用一個 非空 單鏈表來表示一個非負整數&#xff0c;然后將這個整數加一。 你可以假設這個整數除了 0 本身&#xff0c;沒有任何前導的 0。 這個整數的各個數位按照 高位在鏈表頭部、低位在鏈表尾部 的順序排列。 示例: 輸入: [1,2,3] 輸出: [1,2,4] 思路&#xff1a; hel…

MySQL常見的兩種存儲引擎:MyISAM與InnoDB的愛恨情仇

一 MyISAM 1.1 MyISAM簡介 MyISAM是MySQL的默認數據庫引擎&#xff08;5.5版之前&#xff09;&#xff0c;由早期的 ISAM &#xff08;Indexed Sequential Access Method&#xff1a;有索引的順序訪問方法&#xff09;所改良。雖然性能極佳&#xff0c;而且提供了大量的特性&a…

leetcode193. 有效電話號碼 正則了解一下

給定一個包含電話號碼列表&#xff08;一行一個電話號碼&#xff09;的文本文件 file.txt&#xff0c;寫一個 bash 腳本輸出所有有效的電話號碼。 你可以假設一個有效的電話號碼必須滿足以下兩種格式&#xff1a; (xxx) xxx-xxxx 或 xxx-xxx-xxxx。&#xff08;x 表示一個數字…

leetcode258. 各位相加

給定一個非負整數 num&#xff0c;反復將各個位上的數字相加&#xff0c;直到結果為一位數。 示例: 輸入: 38 輸出: 2 解釋: 各位相加的過程為&#xff1a;3 8 11, 1 1 2。 由于 2 是一位數&#xff0c;所以返回 2。 進階: 你可以不使用循環或者遞歸&#xff0c;且在 O(…

leetcode412. Fizz Buzz

寫一個程序&#xff0c;輸出從 1 到 n 數字的字符串表示。 1. 如果 n 是3的倍數&#xff0c;輸出“Fizz”&#xff1b; 2. 如果 n 是5的倍數&#xff0c;輸出“Buzz”&#xff1b; 3.如果 n 同時是3和5的倍數&#xff0c;輸出 “FizzBuzz”。 示例&#xff1a; n 15, 返…

leetcode359. 日志速率限制器

請你設計一個日志系統&#xff0c;可以流式接收日志以及它的時間戳。 該日志會被打印出來&#xff0c;需要滿足一個條件&#xff1a;當且僅當日志內容 在過去的 10 秒鐘內沒有被打印過。 給你一條日志的內容和它的時間戳&#xff08;粒度為秒級&#xff09;&#xff0c;如果這…

怎樣提高WebService性能大數據量網絡傳輸處理(轉)

1. 直接返回DataSet對象 特點&#xff1a;通常組件化的處理機制&#xff0c;不加任何修飾及 處理&#xff1b; 優點&#xff1a;代碼精減、易于處理&#xff0c;小數據量處理較快&#xff1b; 缺點&#xff1a;大數據量的傳遞處理慢&#xff0c;消耗網絡資源&#xff1b; 建議&…

【中國互聯網江湖30年歷史】再無風清揚,再有少年郎

0 馬云退了。 在蕭山奧體中心&#xff0c;無數阿里人的祝福中&#xff0c;流著眼淚&#xff0c;結束了自己在阿里的最后一天。 從此互聯網江湖再無風清揚&#xff0c;反而多了一個叫做馬云的鄉村教師。 他臨別一揮手&#xff0c;似乎帶走了中國互聯網的一個時代。 20年浮沉&…

互聯網30年,泡沫如夢

人人都說互聯網改變世界&#xff0c;這話沒錯。 但我認為互聯網改變的方式&#xff0c;是泡沫。 資金&#xff0c;資源&#xff0c;人才因為一堆概念聚在一起&#xff0c;形成一個又一個的泡沫&#xff0c;然后泡沫破裂&#xff0c;大部分人失敗&#xff0c;少數能夠留下來的&a…

cpp知識匯總(1) 指針vs引用、static、const

引用和指針的區別&#xff1f; 指針是一個實體&#xff0c;需要分配內存空間。引用只是變量的別名&#xff0c;不需要分配內存空間。引用在定義的時候必須進行初始化&#xff0c;并且不能夠改變。指針在定義的時候不一定要初始化&#xff0c;并且指向的空間可變。&#xff08;…

【精品計劃 附錄2】- 算法分析

數學模型 1. 近似2. 增長數量級3. 內循環4. 成本模型 注意事項 1. 大常數2. 緩存3. 對最壞情況下的性能的保證4. 隨機化算法5. 均攤分析 ThreeSum 1. ThreeSumSlow2. ThreeSumBinarySearch3. ThreeSumTwoPointer 倍率實驗 數學模型 1. 近似 N3/6-N2/2N/3 ~ N3/6。使用 ~f(N) …

俄羅斯方塊(C++)

#include<iostream> #include<stdlib.h> #include<windows.h> #include<time.h> #include<conio.h> using namespace std;#define A1 0//A代表長條型&#xff0c;B為方塊&#xff0c;C為L型&#xff0c;D為閃電型&#xff08;實在無法描述那個形…

leetcode445. 兩數相加 II

給你兩個 非空 鏈表來代表兩個非負整數。數字最高位位于鏈表開始位置。它們的每個節點只存儲一位數字。將這兩數相加會返回一個新的鏈表。 你可以假設除了數字 0 之外&#xff0c;這兩個數字都不會以零開頭。 進階&#xff1a; 如果輸入鏈表不能修改該如何處理&#xff1f;換…