java hashMap 查询效率非常高,看一下根据key找value,根据value找key

java hashMap 查询效率非常高,看一下根据key找value,根据value找key@TestpublicvoidtestMap(){Map map=newHashMap();//step1加密字符键字母charc=’a’;for(inti=2;iintk=(i==7||i==9)?4:3;for(intj=1;jStringvalue=””+i+j;map.put(c,value);c++;}}/

大家好,又见面了,我是你们的朋友全栈君。@Test
public void testMap(){


Map<Character, String>  map=new HashMap<Character, String>();
//step1 加密字符键 字母
char c=’a’;
for(int i=2;i<=9;i++){

int k=(i==7|| i==9)?4:3;
for(int j=1;j<=k;j++){

String value=””+i+j;
map.put(c, value);
c++;
}
}
//step2  加密字符  空格 逗号 句号
map.put(‘ ‘, “11”);
map.put(‘,’, “12”);
map.put(‘.’, “13”);

//step3 从0开始循环放入数字
for(c=’0′;c<=’9′;c++){

String value=c+”0″;
map.put(c, value);
}
System.out.println(map);
String msg=”no zuo no die.”;

StringBuilder sb=new StringBuilder(msg.length()*2);


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

String value=map.get(msg.charAt(i));
if(value!=null){

   sb.append(value);
}else{

System.out.println(“包含不能识别的字符”);
break;
}
}
if(sb.length()==msg.length()*2){

System.out.println(“原文”+msg);
System.out.println(“密文”+sb.toString());
}

//解密:
String cypt=sb.toString();
              StringBuilder  sb2=new StringBuilder();
Set<Entry<Character, String>> entrySet=map.entrySet();
for(int i=0;i<cypt.length();i+=2){


String sub=cypt.substring(i,i+2);
System.out.println(sub);
for(Entry<Character, String> entry:entrySet){

//当前子字符串和entry中的value比较
if(sub.equals(entry.getValue())){

sb2.append(entry.getKey());
break;//一旦找到匹配的key就不在寻找。
}
}
}

if(sb2.length()==cypt.length()/2){

System.out.println(“解密成功”+sb2.toString());
}else{

System.out.println(“解密失败”);
}

 
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163576.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月23日 上午11:46
下一篇 2022年7月23日 上午11:46


相关推荐

  • OpenGL中的投影使用

    OpenGL中的投影使用

    2021年11月28日
    43
  • Cursor 教程 – Agent 使用指南

    Cursor 教程 – Agent 使用指南

    2026年3月15日
    2
  • 十进制小数转化为二进制小数[通俗易懂]

    十进制小数转化为二进制小数[通俗易懂]一、二进制数转换成十进制数由二进制数转换成十进制数的基本做法是,把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。这种做法称为”按权相加”法。例如把二进制数110.11转换成十进制数。二、十进制数转换为二进制数十进制数转换为二进制数时,由于整数和小数的转换方法不同,所以先将十进制数的整数部分和小数部分分别转换后,再加以合并。1.十进制整数转换为二进制整数十进制整数转换为二进制整数采用”除2取余,逆序排列”法。具体做法是:用2去除十进制整数,可以得到一个商和余数;再

    2026年3月10日
    3
  • 1084 Broken Keyboard (20分)

    1084 Broken Keyboard (20分)Onabrokenkey someofthekey Sowhenyoutyp thecharacter Nowgivenastr

    2026年3月17日
    1
  • sbc音频编解码是什么_编解码算法工程师

    sbc音频编解码是什么_编解码算法工程师转自:https://blog.csdn.net/wzz4420381/article/details/48676921原作者:wzz4420381 1.SBC算法简介SBC是subbandcode的缩写,也可称为子带编码 在A2DP协议中,SBC算法是默认支持的 蓝牙SBC算法是一种以中等比特率传递高质量音频数据的低计算复杂度的音频编码算法1.1算法基本框图SB…

    2025年10月26日
    4
  • 端口timewait如何解决_如何检测端口状态

    端口timewait如何解决_如何检测端口状态网上查了一下端口状态的资料,我下面总结了一下,自己学习学习:TCP状态转移要点TCP协议规定,对于已经建立的连接,网络双方要进行四次握手才能成功断开连接,如果缺少了其中某个步骤,将会使连接处于假死状态,连接本身占用的资源不会被释放。网络服务器程序要同时管理大量连接,所以很有必要保证无用连接完全断开,否则大量僵死的连接会浪费许多服务器资源。在众多TCP状态中,最值得注意的状态有两个:C……

    2025年9月26日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号