免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3747 | 回复: 3
打印 上一主题 下一主题

用 Haskell 做了一个简单的 Vigenre 加密 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-12 10:15 |显示全部楼层 |倒序浏览
Vigenre 加密算法是一个简单替换密码。我的同学大多都用 Java、VB、VC 来实现。
但我想 Haskell 这样的语言去做这样的数学问题应该是很简单的,所以昨天晚上做了一下尝试。
另外还用 wxHaskell 做了一个很简单的界面。

目前算法的情况是,只支持大写字母的加密,小写字母会自动转化成大写字母,还不支持标点。但是要进行改进的话应该也不难。

存在的问题是:
1. 不清楚如何在 Haskell 中使用中文,好像是与编码有关。
2. 运行用 GHC 编译之后的 exe 文件,除了主窗口之外,后面还会出来一个 CMD 一样的窗口,很是难看。
希望知道解决问题方法的前辈们给一下指点。

附件中有两个文件:Vigenre.hs 是算法实现,VigenreFrame.hs 是界面代码。
希望大家多多拍砖。

编译环境是:Windows XP + GHC 6.8.3 + wxHaskell 0.10.3

核心算法如下:

  1. module Vigenre (encrypt, decrypt)
  2.     where

  3. import Data.List
  4. import Char

  5. -----------------------------------------------------------------
  6. -- helper functions

  7. alphaString :: String
  8. alphaString = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"

  9. line :: Int -> String
  10. line n = b ++ a
  11.     where
  12.       (a, b) = splitAt n alphaString

  13. indexOfElement :: Char -> Int -> Int
  14. indexOfElement e n = i
  15.     where
  16.       (Just i) = elemIndex e (line n)

  17. offset :: Char -> Int
  18. offset x = ord x - ord 'A'

  19. adjustKey :: String -> String -> String
  20. adjustKey m k = map toUpper ((concat $ replicate quotient k)
  21.                              ++ take remainder k)
  22.     where
  23.       quotient =  length m `div` length k
  24.       remainder = length m `mod` length k

  25. -----------------------------------------------------------------


  26. encrypt :: String -> String -> String
  27. encrypt msgString keyString = zipWith encrypt' msgString' keyString'
  28.     where
  29.       encrypt' m k = (line $ offset k) !! (offset m)
  30.       keyString' = map toUpper (adjustKey msgString keyString)
  31.       msgString' = map toUpper msgString
  32.       
  33. decrypt :: String -> String -> String
  34. decrypt msgString keyString = zipWith decrypt' msgString' keyString'
  35.     where
  36.       decrypt' m k = chr (indexOfElement m (offset k) + ord 'A')
  37.       keyString' = map toUpper (adjustKey msgString keyString)
  38.       msgString' = map toUpper msgString
复制代码


[ 本帖最后由 swordfish.cn 于 2008-9-12 10:23 编辑 ]

Vigenre.zip

1.52 KB, 下载次数: 92

论坛徽章:
0
2 [报告]
发表于 2008-09-12 17:01 |显示全部楼层
原帖由 drunkedcat 于 2008-9-12 16:43 发表
望洋兴叹中,我什么时候才能到这样的水平呀?。。。。
努力学习中。。。


很简单的,我也是现炒现卖而已。

论坛徽章:
0
3 [报告]
发表于 2008-09-12 17:04 |显示全部楼层
MMMIX 能否帮我看一下那两个问题怎么解决?多谢。

论坛徽章:
0
4 [报告]
发表于 2008-09-12 17:29 |显示全部楼层
问题是,我现在不用 Windows 不行。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP