package cn.longxuzi;

import org.junit.Test;

public class Chi_SquareUtils {

private static final ICUtils icUtils = new ICUtils();

/**

* @author信息111李继华(LiJiHua)

* @param String

*            [][]ciphertext

* @return null

* @Date 2013-11-21 PM 19:23

* @copyright李继华所有

*/

@Test

public void chi_square() {

String[][] ciphertext = icUtils.devideCipherText();// 获取密文划分以后的每一小组的密文数组

String[] freList = { "A=8.167", "B=1.492", "C=2.782", "D=4.253",

"E=12.702", "F=2.228", "G=2.015", "H=6.049", "I=6.996",

"J=0.153", "K=0.772", "L=4.025", "M=2.406", "N=6.749",

"O=7.507", "P=1.929", "Q=0.095", "R=5.987", "S=6.327",

"T=9.056", "U=2.758", "V=0.978", "W=2.360", "X=0.150",

"Y=1.974", "Z=0.074" };// 频率分布表构成的字符串数组

int count = 0;// 计数器(计算每一个英文字母出现的次数)

double index = 0;// 临时存储每一组密文的X^2得到的值

double[] x = new double[ciphertext.length];// 创建存储每一组密文X值的double型数组容器

int[][] sum1 = new int[ciphertext.length][freList.length];// 创建用来存储每一组每个英文字母出现的次数的整形数组容器

double[][] sum2 = new double[ciphertext.length][freList.length];// 创建存储每一组每个密文字母的(C-E)/E值

for (int i = 0; i < ciphertext.length; i++) {// 第一层循环遍历根据密钥长度分成的每一小组密文

for (int j = 0; j < freList.length; j++) {// 第二层循环遍历频率分布表中每个字母在每一小组密文中是否出现以及它们的频率

String flag = freList[j].substring(0, 1);// 临时存储取到的第J个英文字母

double E = Double.parseDouble(freList[j].substring(2,

freList[j].length()));// 临时存储取到的第J个字母对应的频率值

for (int k = 0; k < ciphertext[0].length; k++) {// 第三层循环遍历每一个密文小组中每一个密文字母

if (flag.equals(ciphertext[i][k])) {// 根据字母表顺序依次判断每一个英文字母是否在密文小组中出现了

count++;// 如果出现,开始计数每一个英文字母在小组密文字母表中总共出现的次数

}

}

sum1[i][j] = count;// 赋值给用来存储字母出现次数的数组容器

count = 0;// 计数器清零

double dis = (double) (sum1[i][j] - E);

sum2[i][j] = (dis * dis) / E;

}

}

for (int i = 0; i < ciphertext.length; i++) {

for (int j = 0; j < freList.length; j++) {

index += sum2[i][j];

}

x[i] = index;

index = 0;

System.out.println("第" + (i + 1) + "小组的X值为" + Math.sqrt(x[i]));

}

}

// 以下是计算每一个密文小组X值的测试代码

public static void main(String[] args) {

while (true) {

Chi_SquareUtils ch = new Chi_SquareUtils();

ch.chi_square();

}

}

}

维吉尼亚密码java完整版的更多相关文章

  1. 维吉尼亚密码java代码实现根据密钥长度计算IC值过程

    package cn.longxuzi; import java.util.Scanner; import org.junit.Test; public class ICUtils { /** * @ ...

  2. 维吉尼亚密码-攻防世界(shanghai)

    维吉尼亚密码 维吉尼亚密码是使用一系列 凯撒密码 组成密码字母表的加密算法,属于多表密码的一种简单形式. 加密原理 维吉尼亚密码的前身,是我们熟悉的凯撒密码. 凯撒密码的加密方式是依靠一张字母表中的每 ...

  3. [CTF]维吉尼亚密码(维基利亚密码)

    [CTF]维吉尼亚密码(维基利亚密码) ----------------------百度百科 https://baike.baidu.com/item/维吉尼亚密码/4905472?fr=aladdi ...

  4. Vigenère Cipher 维吉尼亚加解密算法

    维吉尼亚的加解密有两种方法. 第一种是查表:第一行为明文,第一列为密钥,剩余的为对应的密文 第二种方法是转化计算法:逐个将字符转化为从零开始的数字,对数字进行加密/解密后,再转化为字符. 本文要用c+ ...

  5. [加密]C#实现维吉尼亚加密与解密(解密前提为已知密匙)

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  6. 随机练习:C#实现维吉尼亚加密与解密(解密前提为已知密匙)

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  7. python 维吉尼亚

    加密key='COMPUTER' plaintext='BLOCKCIPHERDESIGNPRINCIPLE' ascii='abcdefghijklmnopqrstuvwxyz'.upper() k ...

  8. python实现维吉尼亚解密

    # -*-coding:UTF-8-*- from sys import stdout miwen = "KCCPKBGUFDPHQTYAVINRRTMVGRKDNBVFDETDGILTXR ...

  9. python实现维吉利亚密码加密(Vigenère cipher)

    最近有个朋友问我关于维吉利亚密码如何用python实现加密,研究之后发现这是个挺好玩的东西,遂决定写篇博文记录一下. 一.何谓维吉利亚密码 第一列是密钥字母列,第一行是明文字母行.不难看出维吉利亚密码 ...

随机推荐

  1. QML Image得到的图片资源路径的详细信息

    最近又开始了Qt5.在学习QML当地的资源总是越来越留念类似 " QML Image: Cannot open: qrc:///images/Blue hills.jpg "的错误 ...

  2. ExtJS4 自己定义基于配置的高级查询1

    今天在编码过程中遇到一个问题,临时还没解决,先记录下来 上面是我做的高级查询面板..字段名和值都是读取配置文件,依据用户选择不同的字段名,自己主动载入不同的值列表,关系是与或 问题来了,我在字段名那个 ...

  3. openwrt路由器更换了Flash之后需要修改的源码

    假如我使用的是WR703N,改为8M内存: 1 修改openwrt/target/linux/ar71xx/image/Makefile文件 $(eval $(call SingleProfile,T ...

  4. MySQL之查询优化方式(笔记)

    1.COUNT() 对COUNT的优化可以通过下面的SQL实现 mysql> select count(gnp<10000 or null) as '<<<<',c ...

  5. Android项目--XML解析

    对于xml文件,一般有两种解析方式: -----pull解析-------- -----Sax解析------- 如果xml文件是本地文件,那么就好说了 AssetManager assetManag ...

  6. javascript this指向

    this对象是什么: this对象是与运行时函数执行的上下文绑定的.这句话其实已经很好的解释了this对象,为我们确定this指明了方向!但是需要注意的是:由于javascript具有动态性(解释执行 ...

  7. sqlclr返回数据集案例

    ----------------------------------------------返回一张表,但只有一条数据,最后一次设置的. [Microsoft.SqlServer.Server.Sql ...

  8. oracle 表导入到powerDesigner 中

    最近不忙,之前一直是用powerDesigner看表结构,还没自己导入过,今天试试 oracle 表导入到powerDesigner 中步骤: 1.File--->reverse Enginne ...

  9. [QT Creator]LNK1123: 转换到 COFF 期间失败: 文件无效或损坏 。

    这个问题很恶心!网上说的原因是因为安装了多了版本的VS.在高版本的2010和2012上都会有问题,解决方法是使用visual studio 2008安装目录下的一个文件替代vs2010安装目录下的文件 ...

  10. [转]Bypassing iOS security

    src: http://blog.thireus.com/tag/kernelcache Before going further it is important to enumerate some ...