66666666600000 2022-04-06 09:24 采纳率: 87.5%
浏览 52
已结题

凯撒密码解密字符串。

利用map,使用凯撒密码(k=3)将字符串“trphzdvqrw exlowlqdgdb.”进行解密,结果错误。

  • 写回答

2条回答 默认 最新

  • sanshizhang 2022-04-06 10:24
    关注

    package com.test.kaisamima;

    import java.util.HashMap;
    import java.util.Map;

    /**

    • 凯撒密码

    • @date 2022/04/06

    • /
      public class Kaisamima {
      private static final String str = "abcdefghijklmnopqrstuvwxyz";

      public static void main(String[] args) {

        // TODO Auto-generated method stub
        Map<Character, Character> map = init(3);
        String s = "trphzdvqrw exlowlqdgdb.";
        char[] ss = s.toCharArray();
        StringBuffer sb = new StringBuffer();
        for (char c : ss) {
            Character cc = map.get(c);
            if (cc == null) {
                cc = c;
            }
            sb.append(cc);
        }
        System.out.println(sb + "===========");
      

      }

      private static Map<Character, Character> init(int k) {

        Map<Character, Character> map = new HashMap<Character, Character>();
        char strs[] = str.toCharArray();
        for (char c : strs) {
            int i = str.indexOf(c);
            int index = i + k;
            if (index >= strs.length) {
                index = index % strs.length;
            }
            map.put(c, strs[index]);
        }
        return map;
      

      }
      }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月23日
  • 已采纳回答 4月15日
  • 创建了问题 4月6日

悬赏问题

  • ¥15 Torch not compiled with CUDA enabled
  • ¥15 三种节点编号优化算法比较
  • ¥15 比特币ord程序wallet_constructor.rs文件支持一次性铸造1000个代币,并将它们分配到40个UTXO上(每个UTXO上分配25个代币),并设置找零地址
  • ¥115 用Java解决探地雷达dzt文件的解析过程
  • ¥20 有关神经网络这道(b)determine the parameters of neural network
  • ¥25 annaconda jvpyter
  • ¥20 来一个会抓包app支付接口的
  • ¥30 vivado2017.4的sdk打不开
  • ¥50 matlab,文献复现
  • ¥20 寻找Flink CDC指导,有偿咨询