维吉尼亚密码java代码实现根据密钥长度计算IC值过程
package cn.longxuzi;
import java.util.Scanner;
import org.junit.Test;
public class ICUtils {
/**
* @author龙须子(XuziLong)
* @param null
* @return String [][]devideCipherText
* @Date 2013-11-20 PM 19:00
*/
public String[][] devideCipherText() {
// 根据密钥长度将密文分解成密钥长度个小组
String[][] str;
System.out.println("请输入密文字符串(以回车键结束)");
Scanner sc = new Scanner(System.in);
String ciphertext = sc.nextLine().toUpperCase().trim();
System.out.println("请输入密钥长度(以回车键结束)");
int keyLength = sc.nextInt();
// 计算每一组最多有多少个字母
int amount = 0;
if (ciphertext.length() % keyLength == 0) {
amount = ciphertext.length() / keyLength;
} else {
amount = (ciphertext.length() / keyLength) + 1;
}
// 初始化存储分开组的密文的字符串数组
str = new String[keyLength][amount];
int flag = 0, i = 0;
for (int j = 0; j < keyLength; j++) {
for (int k = 0; k < amount; k++) {
if (i + 1 > ciphertext.length()) {
break;
}
str[j][k] = ciphertext.substring(i, i + 1);
i = i + keyLength;
}
i = flag + 1;
flag++;
}
return str;
}
/**
* @author龙须子(XuziLong)
* @param String
* [][]
* @return double Every[]IC value
* @Date 2013-11-20 PM 19:23
*/
public double[] getIC(String[][] str) {
// 计算每一小组密文的IC值
double[] IC = new double[str.length];
char[] letter = { 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77,
78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90 };// 创建字母表数组
int[][] sum = new int[str.length][letter.length];// 创建存放每个密文小组中每个字母出现次数的数组
int count = 0;// 计数器
for (int i = 0; i < str.length; i++) {
for (int j = 0; j < letter.length; j++) {
for (int k = 0; k < str[0].length; k++) {
if (String.valueOf(letter[j]).toUpperCase()
.equals(str[i][k])) {
count++;
}
}
sum[i][j] = count;
count = 0;
}
}
double[] result = new double[IC.length];
for (int j = 0; j < str.length; j++) {
for (int k = 0; k < letter.length; k++) {
if (sum[j][k] != 0) {
result[j] += sum[j][k] * (sum[j][k] - 1);
}
}
}
double N = (double) (str.length * str[0].length);
for (int j = 0; j < IC.length; j++) {
IC[j] = (double) (result[j] / (N * (N - 1)));
}
return IC;
}
/**
* @author龙须子(XuziLong)
* @param double[]IC
* @return double average []IC
* @Date 2013-11-21 PM 19:23
*/
public double getAverageIC(double[] IC) {
// 计算所有密文小组IC的平均值
double result = 0;
for (int i = 0; i < IC.length; i++) {
result += IC[i];
}
return result / (double) (IC.length);
}
//以下是求每一个密文小组IC值及分组情况的测试代码
@Test
public void tests() {
while (true) {
ICUtils tes = new ICUtils();
String[][] str = tes.devideCipherText();
for (int i = 0; i < str.length; i++) {
System.out.print("第" + (i + 1) + "小组的密文字母串为:");
for (int k = 0; k < str[0].length; k++) {
if (str[i][k] == null) {
str[i][k] = "";
}
System.out.print(str[i][k]);
}
System.out.println();
}
double[] ic = tes.getIC(str);
for (int j = 0; j < ic.length; j++) {
System.out.println("该小组密文的IC值为:" + ic[j]);
}
System.out.println("本次分组中IC的平均值为:"
+ tes.getAverageIC(tes.getIC(str)));
}
}
}
维吉尼亚密码java代码实现根据密钥长度计算IC值过程的更多相关文章
- 维吉尼亚密码java完整版
package cn.longxuzi; import org.junit.Test; public class Chi_SquareUtils { private static final ICUt ...
- 维吉尼亚密码-攻防世界(shanghai)
维吉尼亚密码 维吉尼亚密码是使用一系列 凯撒密码 组成密码字母表的加密算法,属于多表密码的一种简单形式. 加密原理 维吉尼亚密码的前身,是我们熟悉的凯撒密码. 凯撒密码的加密方式是依靠一张字母表中的每 ...
- [CTF]维吉尼亚密码(维基利亚密码)
[CTF]维吉尼亚密码(维基利亚密码) ----------------------百度百科 https://baike.baidu.com/item/维吉尼亚密码/4905472?fr=aladdi ...
- Vigenère Cipher 维吉尼亚加解密算法
维吉尼亚的加解密有两种方法. 第一种是查表:第一行为明文,第一列为密钥,剩余的为对应的密文 第二种方法是转化计算法:逐个将字符转化为从零开始的数字,对数字进行加密/解密后,再转化为字符. 本文要用c+ ...
- [加密]C#实现维吉尼亚加密与解密(解密前提为已知密匙)
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- 随机练习:C#实现维吉尼亚加密与解密(解密前提为已知密匙)
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- python 维吉尼亚
加密key='COMPUTER' plaintext='BLOCKCIPHERDESIGNPRINCIPLE' ascii='abcdefghijklmnopqrstuvwxyz'.upper() k ...
- python实现维吉尼亚解密
# -*-coding:UTF-8-*- from sys import stdout miwen = "KCCPKBGUFDPHQTYAVINRRTMVGRKDNBVFDETDGILTXR ...
- JAVA代码根据经纬度范围计算WGS84与谷歌全球墨卡托包含的切片数目与拼接图像像素尺寸
根据项目需求编写的代码. 适用场景:在网络地图上,比如天地图与谷歌地图,用户用鼠标在地图上拉一个矩形框,希望下载该矩形框内某一层级的瓦片数据,并将所有瓦片拼接成一个完整的,包含地理坐标的tif图像. ...
随机推荐
- POJ 3654 & ZOJ 2936 & HDU 2723 Electronic Document Security(模拟)
题目链接: PKU:http://poj.org/problem?id=3654 ZJU:http://acm.zju.edu.cn/onlinejudge/showProblem.do?proble ...
- 表单验证的3个函数ISSET()、empty()、is_numeric()的使用方法
原文:表单验证的3个函数ISSET().empty().is_numeric()的使用方法 本文就简单讲一下php中表单验证的三个函数,应该比较常用吧,最后给一些示例,请看下文. ISSET();—— ...
- 大约php,mysql,html数字寻呼和文本分页2分页样式供大家参考
做盗版.转载请添加源http://blog.csdn.net/yanlintao1 请勿盗版,转载请加上出处http://blog.csdn.net/yanlintao1 首先进行样式展示希望对大家有 ...
- WebIM(5)----将WebIM嵌入到页面中
在之前的文章中,已经开发了一个简单的WebIM,但是这个WebIM是在独立的页面中的,今天发布的WebIM是一个可以嵌入到自己网页中的版本,你只需添加少量的代码,就可以在页面中嵌入一个WebIM.不过 ...
- 从Http它被连接到WebSocket
1.HTTP协议长期-fi支持和各支持的浏览器 http://blog.csdn.net/fenglibing/article/details/7100222 2.WEBclient与服务端信息交互的 ...
- OpenGL绘制棱锥,剔除
/** * 缓冲区工具类 */public class BufferUtil { /** * 将浮点数组转换成字节缓冲区 */ public static ByteBuffer arr2ByteB ...
- C#编程断点续传
C#编程总结(十二)断点续传 Posted on 2014-02-16 10:56 停留的风 阅读(384) 评论(3) 编辑 收藏 C#编程总结(十二)断点续传 我们经常使用下载工具,如bit精灵. ...
- JAVA学习:异常
一.异常官方定义: 1.就是不正常.程序在运行时出现的不正常情况.其实就是程序中出现的问题.这个问题按照面向对象思想进行描述,并封装成了对象.因为问题的产生有产生的原因.有问题的名称.有问题的描述等多 ...
- Linq无聊练习系列1--where练习
linq主要有3种,linq to sql,linq to XML,Linq to Object linq to sql. 这里没有通过相应的类,生成相应的数据库中的表.没有用流行的编码优先. 只是为 ...
- socket网络编程快速上手(二)——细节问题(5)(完结篇)
6.Connect的使用方式 前面提到,connect发生EINTR错误时,是不能重新启动的.那怎么办呢,是关闭套接字还是直接退出进程呢?如果EINTR前,三次握手已经发起,我们当然希望链路就此已经建 ...