题解 | #简单密码#

简单密码

https://www.nowcoder.com/practice/7960b5038a2142a18e27e4c733855dac

package NewComer;

import java.util.HashMap;
import java.util.Scanner;
import java.util.Map;
import java.util.Set;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class  HJ21_简单密码 {
  private static Map<String,String> map = new HashMap<>();
  static{     //静态初始化、加载map容器
    map.put("1","1");
    map.put("abc","2");
    map.put("def","3");
    map.put("ghi","4");
    map.put("jkl","5");
    map.put("mno","6");
    map.put("pqrs","7");
    map.put("tuv","8");
    map.put("wxyz","9");
    map.put("0","0");
  }

  public static void main(String[] args) {
    Scanner in = new Scanner(System.in);
    String s1 = in.nextLine();
    char c1[] = s1.toCharArray(); //转传承char型数组
    StringBuffer sb = new StringBuffer();
    //Map stringMap = new HashMap();

    for(char c : c1){
      if(c>'1' && c<='9'){
        sb.append(String.valueOf(c));  //如果是数字就保持不变
      }
      else if(c>='A' && c<='Y'){
        char newchar = (char)(c+32+1);  //字符串大小写技巧
        sb.append(String.valueOf(newchar));
      }
      else if(c == 'Z'){
        sb.append('a');
      }
      else{  //最后一种情况,做映射,即去除map容器中的key与字符进行校验并加密
        Set<String> keys = map.keySet();  //keySet()函数用于获得map集合里的key值集合。
        for(String k:keys){
          if(k.contains(String.valueOf(c))){  //查看keys集合中有没有输入的字符
            sb.append(String.valueOf(map.get(k)));  //通过k得到想要映射的结果
          }
        }
      }

    }
    System.out.print(sb);

  }
}

全部评论

相关推荐

03-26 13:04
已编辑
电子科技大学 算法工程师
xiaowl:你这个简历“条目上”都比较有深度性,但是实际上面试官又没法很好的评估你是怎么达到很多看上去很厉害的结果的。要避免一些看上去很厉害的包装,比如高效的内存复用策略的表达,如果仅是简单的一些内存共享机制,而且面试上也没有深挖的空间,就不要这样表达。比如,工程化模式本质上可能就是定义了一些abstract class,那也就没特别多值得讲的内容。建议简历上应该侧重那些你花了大量时间和精力解决、研究的问题,不要过分追求“丰富”,而是关注在技术深入度、问题解决能力的表现上。
没有实习经历,还有机会进...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务