自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用 Go 語言實(shí)現(xiàn)凱撒加密

開發(fā) 前端
在 2 世紀(jì), 發(fā)送機(jī)密消息的一個(gè)有效方法就是對(duì)每個(gè)字母進(jìn)行位移, 使得 'a' 變?yōu)?'d' , 'b' 變?yōu)?'e' , 依次類推。

在 2 世紀(jì), 發(fā)送機(jī)密消息的一個(gè)有效方法就是對(duì)每個(gè)字母進(jìn)行位移, 使得 'a' 變?yōu)?'d' , 'b' 變?yōu)?'e' , 依次類推。 這樣處理產(chǎn)生的結(jié)果看上去就像是一門外語:

L fdph, L vdz, L frqtxhuhg. —— 尤利烏斯·凱撒(Julius Caesar)

正如代碼清單 9-6 所示, 使用計(jì)算機(jī)以數(shù)值方式處理字符是非常容易的。

 

[[337383]]

代碼清單 9-6 處理單個(gè)字符: caesar.go

  1. c := 'a' 
  2. c=c+3 
  3. fmt.Printf("%c", c)    // 打印出“d” 

然而, 代碼清單 9-6 展示的方法并不完美, 因?yàn)樗鼪]有考慮該如何處理字符 'x' 、 'y' 和 'z' , 所以它無法對(duì) xylophones 、 yaks 和 zebras 這樣的單詞實(shí)施加密。 為了解決這個(gè)問題, 最初的凱撒加密法采取了回繞措施, 也就是將 'x' 變?yōu)?'a' 、 'y' 變?yōu)?'b' , 而 'z' 則變?yōu)?'c' 。 對(duì)于包含 26 個(gè)字符的英文字母表, 我們可以通過這段代碼實(shí)現(xiàn)上述變換:

  1. if c > 'z' { 
  2.     c = c - 26 

凱撒密碼的解密方法跟加密方法正好相反, 程序不再是為字符加上 3 而是減去 3 , 并且它還需要在字符過小也就是 c < 'a' 的時(shí)候, 將字符加上 26 以實(shí)施回繞。 雖然上述的加密方法和解密方法都非常直觀, 但由于它們都需要處理字符邊界以實(shí)現(xiàn)回繞, 因此實(shí)際的編碼過程將變得相當(dāng)痛苦。

回轉(zhuǎn)13(rotate 13,簡稱ROT13)是凱撒密碼在 20 世紀(jì)的一個(gè)變體, 該變體跟凱撒密碼的唯一區(qū)別就在于, 它給字符添加的量是 13 而不是 3 , 并且 ROT13 的加密和解密可以通過同一個(gè)方法實(shí)現(xiàn), 這是非常方便的。

現(xiàn)在, 假設(shè)搜尋外星智能(Search for Extra-terrestrial Intelligence, SETI)的相關(guān)機(jī)構(gòu)在外太空掃描外星人通信信息的時(shí)候, 發(fā)現(xiàn)了包含以下消息的廣播:

  1. message := "uv vagreangvbany fcnpr fgngvba" 

我們有預(yù)感, 這條消息很可能是使用 ROT13 加密的英文文本, 但是在解密這條消息之前, 我們還需要知悉其包含的字符數(shù)量, 這條消息包含 30 個(gè)字符, 可以通過內(nèi)置的 len 函數(shù)來確定:

  1. fmt.Println(len(message)) // 打印出“30” 

注意 Go 擁有少量無須導(dǎo)入語句即可使用的內(nèi)置函數(shù), len 函數(shù)即是其中之一, 它可以測定各種不同類型的值的長度。 例如, 在上面的代碼中, len 返回的就是 string 類型的字節(jié)長度。 代碼清單 9-7 展示的就是外太空消息的解密程序, 你只需要在 Go Playground 運(yùn)行這段代碼, 就會(huì)知道外星人在說什么了。

代碼清單 9-7 ROT13 消息解密: rot13.go

  1. message := "uv vagreangvbany fcnpr fgngvba" 
  2.  
  3. for i := 0; i < len(message); i++ {    // 迭代字符串中的每一個(gè) ASCII 字符 
  4.     c := message[i] 
  5.     if c >= 'a' && c <= 'z' {    // 只解密英文字母,至于空格和標(biāo)點(diǎn)符號(hào)則保持不變 
  6.         c = c + 13 
  7.         if c > 'z' { 
  8.             c = c - 26 
  9.         } 
  10.     } 
  11.     fmt.Printf("%c", c) 

注意, 這段代碼中的 ROT13 實(shí)現(xiàn)只能處理 ASCII 字符(字節(jié)), 它無法處理用西班牙語或者俄語撰寫的消息, 不過接下來的一節(jié)將會(huì)給出這個(gè)問題的解決方案。

責(zé)任編輯:未麗燕 來源: 今日頭條
相關(guān)推薦

2022-10-26 07:26:38

2022-04-18 10:01:07

Go 語言漢諾塔游戲

2023-07-31 08:01:13

二叉搜索測試

2022-11-01 18:29:25

Go語言排序算法

2024-08-29 13:23:04

WindowsGo語言

2023-05-08 07:55:05

快速排序Go 語言

2019-12-16 14:53:44

機(jī)器學(xué)習(xí)人工智能計(jì)算機(jī)

2014-12-26 09:52:08

Go

2022-05-19 14:14:26

go語言限流算法

2012-03-13 10:40:58

Google Go

2022-06-05 23:30:25

AES加密算法

2012-08-06 08:50:05

Go語言

2021-07-12 15:50:55

Go 語言netstat命令

2024-06-06 09:47:56

2021-07-26 09:47:38

Go語言C++

2023-03-27 00:20:48

2021-03-01 18:35:18

Go語言虛擬機(jī)

2021-03-01 21:59:25

編程語言GoCX

2022-07-20 09:52:44

Go語言短信驗(yàn)證碼

2024-08-26 14:32:43

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)