题目描述

有一种技巧可以对数据进行加密,它使用一个单词作为它的密匙。下面是它的工作原理:首先,选择一个单词作为密匙,如TRAILBLAZERS。如果单词中包含有重复的字母,只保留第1个,其余几个丢弃。现在,修改过的那个单词属于字母表的下面,如下所示:

A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

T R A I L B Z E S C D F G H J K M N O P Q U V W X Y

上面其他用字母表中剩余的字母填充完整。在对信息进行加密时,信息中的每个字母被固定于顶上那行,并用下面那行的对应字母一一取代原文的字母(字母字符的大小写状态应该保留)。因此,使用这个密匙,Attack AT DAWN(黎明时攻击)就会被加密为Tpptad TP ITVH。

请实现下述接口,通过指定的密匙和明文得到密文。

详细描述:

接口说明

原型:

voidencrypt(char * key,char * data,char * encrypt);

输入参数:

char * key:密匙

char * data:明文

输出参数:

char * encrypt:密文

返回值:

void

输入描述:

先输入key和要加密的字符串

输出描述:

返回加密后的字符串

示例1

输入

nihao
ni

输出

le

代码如下:

 package com.yzh.xuexi;

 import java.util.Scanner;

 public  class StringJiaMi {

     public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
while(scanner.hasNext()){
System.out.println(stringJiaMi(scanner.nextLine(), scanner.nextLine()));
}
scanner.close();
}
//先去重,再补全,最后对应
private static String stringJiaMi(String miYao,String minWen) {
int[]cLArr=new int[26];
int[]cUArr=new int[26];
StringBuilder stringBuilder=new StringBuilder();
int length=miYao.length();
char c;
//去重
for(int i=0;i<length;i++){
c=miYao.charAt(i);
if (Character.isLowerCase(c)) {
if (cLArr[c-97]==0) {
cLArr[c-97]=1;
stringBuilder.append(c); }
}else {
if(cUArr[c-65]==0){
cUArr[c-65]=1;
stringBuilder.append(c);
}
}
} miYao=stringBuilder.toString();
String tempMiYao=miYao.toUpperCase();
StringBuilder upBuilder=new StringBuilder(tempMiYao);
CharSequence up="ABCDEFGHIJKLMNOPQRSTUVWXYZ";
//补全
for(int i=0;i<26;i++){
if (!tempMiYao.contains(up.subSequence(i, i+1))) {
upBuilder.append(up.subSequence(i, i+1));
}
} StringBuilder resultBuilder=new StringBuilder();
String upString="ABCDEFGHIJKLMNOPQRSTUVWXYZ";
int minWenL=minWen.length();
//对应
for(int i=0;i<minWenL;i++){
int index=0;
if (upString.indexOf(minWen.charAt(i)+"")<0) {
index=upString.indexOf((minWen.charAt(i)+"").toUpperCase());
resultBuilder.append((upBuilder.charAt(index)+"").toLowerCase());
} else {
index=upString.indexOf((minWen.charAt(i)+""));
resultBuilder.append(upBuilder.charAt(index));
}
}
return resultBuilder.toString(); } }

最新文章

  1. Nodejs日志管理包
  2. (旧)子数涵数&#183;PS——文字人物
  3. [STL] lower_bound和upper_bound
  4. Remainder
  5. VMware Workstation 10.0.0.1295980 CN
  6. mysql 闪回表工具
  7. 使用过渡场景在多个场景的切换COCOS2D(4)
  8. android打包apk时混淆遇到的问题
  9. SpringBoot整合阿里云OSS文件上传、下载、查看、删除
  10. Git基本操作指令
  11. Linux下完全删除用户
  12. Spring Mvc配置多视图 - tiles, velocity, freeMarker, jsp
  13. CH 3101 - 阶乘分解 - [埃筛]
  14. BZOJ4259: 残缺的字符串(FFT 字符串匹配)
  15. nginx的80端口跳转到443
  16. outline: none;
  17. 线性回归浅谈(Linear Regression)
  18. iOS-----使用NSOperation与NSOperationQueue实现多线程
  19. phpexcel导入数据出现PHPExcel_RichText Object解决办法
  20. 在 WF 4 中编写自定义控制流活动

热门文章

  1. try or install Ubuntu on MeegoPad T01
  2. sublime text3 汉化
  3. yii表单输入元素
  4. PHP简单操作SqlServer数据库。
  5. idea 添加代码自动提示支持,已PHP扩展 swoole 为例
  6. java json字符串与对象转换
  7. ubuntu16.04搭建geodjango+postgresql+postgis的WebGIS框架(一)安装第三方空间库
  8. Git 上传文件到 码云 gitee
  9. 【坑】tableView cell默认选中
  10. idea 常见快捷键记录下