[关闭]
@yexiaoqi 2022-05-20T16:42:39.000000Z 字数 1055 阅读 500

HJ36. 字符串加密

刷题


题目:有一种技巧可以对数据进行加密,它使用一个单词作为它的密匙。下面是它的工作原理:首先,选择一个单词作为密匙,如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。
请实现下述接口,通过指定的密匙和明文得到密文。
数据范围:1≤n≤100 ,保证输入的字符串中仅包含小写字母

输入描述:先输入key和要加密的字符串
输出描述:返回加密后的字符串

示例1

输入:nihao
      ni
输出:le

链接:https://www.nowcoder.com/practice/e4af1fe682b54459b2a211df91a91cf3


  1. public class Main {
  2. public static void main(String[] args){
  3. Scanner in = new Scanner(System.in);
  4. while(in.hasNext()){
  5. String abc = "abcdefghijklmnopqrstuvwxyz";
  6. String ss = in.next() + abc;
  7. //计算映射关系
  8. List<Character> list = new ArrayList<>();
  9. Map<Character, Character> map = new HashMap<>();
  10. for(int i=0; i<ss.length(); i++) {
  11. char c = ss.charAt(i);
  12. if (!list.contains(c)) {
  13. list.add(c);
  14. map.put(abc.charAt(list.size()-1), c);
  15. }
  16. }
  17. //加密
  18. String s = in.next();
  19. StringBuilder sb = new StringBuilder();
  20. for(int i=0; i<s.length(); i++){
  21. sb.append(map.get(s.charAt(i)));
  22. }
  23. System.out.println(sb);
  24. }
  25. }
  26. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注