這個東西確實可以防蟻,但卻不防蟑螂!!! (竟然還得什麼發明金牌獎…)
之前買來放貓飼料盆,用了一、兩年,最近偶然靠近聞到,裡面已經發出濃烈刺鼻的蟑螂味,又無法打開清洗,在清潔時爬出 5 公分左右的活蟑螂,前幾天也才殺掉一隻來路不明,也是 5 公分左右有翅膀的蟑螂。噴酒精要弄昏它時,它就迅速的往這個盤子的方向逃竄,想必也是住在裡面的。
無法打開,但從味道和掉出來的蟑螂屍渣判斷,裡面應該已經有一整窩的蟑螂在生活。
也許可以搭配蟑螂藥吧?但個人是永遠不敢再用了。
Game Developer Since 1980. [ Forex EA Design Since 2015 Till Now ]
(1980 年起成為遊戲開發者 [2015 年起至今是外匯保證金自動交易程式設計])
這個東西確實可以防蟻,但卻不防蟑螂!!! (竟然還得什麼發明金牌獎…)
之前買來放貓飼料盆,用了一、兩年,最近偶然靠近聞到,裡面已經發出濃烈刺鼻的蟑螂味,又無法打開清洗,在清潔時爬出 5 公分左右的活蟑螂,前幾天也才殺掉一隻來路不明,也是 5 公分左右有翅膀的蟑螂。噴酒精要弄昏它時,它就迅速的往這個盤子的方向逃竄,想必也是住在裡面的。
無法打開,但從味道和掉出來的蟑螂屍渣判斷,裡面應該已經有一整窩的蟑螂在生活。
也許可以搭配蟑螂藥吧?但個人是永遠不敢再用了。
目的:
解決以 bit = 1 之數量多寡為計數方式之數字序列表示,而不以原二進位計算法為數列順序之算數法。
例如,原二進位系統 1 ~ 8 分別為:
0001
0010
0011
0100
0101
0110
0111
1000
齒差轉輪二進位數之 1 ~ 8 ,若以 7 bits 為資料寬度,則分別為:
000 0001 , idx = 0
000 0010 , idx = 1
000 0100 , idx = 2
000 1000 , idx = 3
001 0000 , idx = 4
010 0000 , idx = 5
100 0000 , idx = 6
000 0011 , idx = 7
概念:
=============
1. 現假設實現資料寬度為 7 bits,則單一「齒輪」 (只有 1 個 bit = 1) 就有 7 齒,當轉動 (位元移動) 時,其為 1 之值以下為無效位元,標記為 x ,其上則為 0,表現如下:
000 0001 = 未轉動
000 001x = 轉動 1
000 01xx = 轉動 2
000 1xxx = 轉動 3
依此類推,直到
1xx xxxx = 轉動 6
轉動 7 則代表要進一位,即多一「齒輪」加入運算。
=============
2. 現假設有 2 ~ 7 bits 為 1 ,則為有 2 「齒輪」的狀態,轉動規則為,任何代表較高位元之齒輪皆不得將其有 1 之 bit 旋轉至任何較低位元之齒輪出現 x 之處,舉例,假如第一個齒輪編號為 G0,第二為 G1,則 Gn 為 1 的 bit 放置位置,不可以和 G0 ~ G(n-1) 任何出現 x 的位置重疊,任何齒輪有 1 的 bit,亦不可和任何其他的齒輪有 1 的位置重疊。轉動時則以 Gn 為優先,Gn 轉至「進位」,才轉動 G(n-1),直到 G0 也轉動至無法轉動為止,才再增加一齒輪,表現如下:
2 bits:
轉動 0, 總和值 = 000 0011
000 001x G1
000 0001 G0
轉動 1, 總和值 = 000 0101
000 01xx G1 (左移 1 bit)
000 0001 G0
轉動 2, 總和值 = 000 1001
000 1xxx G1 (再左移 1 bit)
000 0001 G0
直到轉動 5, 總和值 = 100 0001
1xx xxxx G1 (和轉動 0 比,共左移 5 bits)
000 0001 G0
轉動 6 則需「進位」,總和值 = 000 0110
000 01xx G1 (1 不能和 G0 之 1 or x 重疊,所以進位後將被迫再左移 1 bit)
000 001x G0 (發生進位,1 左移 1 bit)
依此類推,直到
轉動 20, 總和值 = 110 0000
1xx xxxx G1
01x xxxx G0
--------------------------------------
若以 4 bits 有 1 為例,則需要 4 個齒輪
轉動 0, 總和值 = 000 1111
000 1xxx G3
000 01xx G2
000 001x G1
000 0001 G0
隨便舉例,直到
轉動 4, 總和值 = 010 1011
001 xxxx G3 (1 不能和 G0 ~ G2 之 1 or x 重疊,所以進位後將被迫再左移 1 bit)
000 1xxx G2 (發生進位,1 左移 1 bit)
000 001x G1
000 0001 G0
轉動 5, 總和值 = 010 1011
01x xxxx G3 (左移 1 bit)
000 1xxx G2
000 001x G1
000 0001 G0
依此類推,直到
轉動 34, 總和值 = 111 1000
1xx xxxx G3
01x xxxx G2
001 xxxx G1
000 1xxx G0
======================
3. 當同樣資料寬度中的 1 數量首次超過 0 的數量時,則可視為 0 與 1 互換之後的鏡射狀況,例如, 000 0011 = 2 bit 為 1,與 001 1111 = 2 bit 為 0,兩種狀況的組合數是相同的。表現如下:
若以 7 bits 寬度為例,則各種「齒輪」所可能的組合數將如下所示
7 齒 111 1111 = 1
6 齒 011 1111 = 7
5 齒 001 1111 = 21
4 齒 000 1111 = 35 (1 數量首次超過 0,開始鏡射)
----------------------
3 齒 000 0111 = 35
2 齒 000 0011 = 21
1 齒 000 0001 = 7
0 齒 000 0000 = 1
======================
4. 組合數的算法,可用 C( N, r ),其中 N = 資料寬度, r = bit = 1 的數量。例如,若有 2 bits 為 1 有多少種組合,則可代入 C( 7, 2 ) = n!/((n-r)!r!) = 7!/(5!2!) = 21
//==================================================================
// Modified from:
https://gist.github.com/tzengyuxio/5478a1f29cb2a8532238#file-binarystatetoindex-cpp// and:
https://gist.github.com/tzengyuxio/554c26d9300e455438be