zoukankan      html  css  js  c++  java
  • 凯撒密码

    问题描述:

    风靡全球的凯撒密码Caesar cipher,又叫移位密码。
    移位密码也就是密码中的字母会按照指定的数量来做移位。

    一个常见的案例就是ROT13密码,字母会移位13个位置。由'A' ↔ 'N', 'B' ↔ 'O',以此类推。
    写一个ROT13函数,实现输入加密字符串,输出解密字符串。
    所有的字母都是大写,不要转化任何非字母形式的字符(例如:空格,标点符号),遇到这些特殊字符,跳过它们。

    参考源:

    String.charCodeAt()
    String.fromCharCode()

    解决方法:

    function rot13(str) {
      var s = '';
      var reg = /^[A-Z]+$/;
      for(var i = 0; i < str.length; i++){
        if(str[i].match(reg)){
          var r = str.charCodeAt(i) > 77? -13: 13;
          var c = str.charCodeAt(i) + r;
          s += String.fromCharCode(c);
        }else{
          s += str[i];
        }
      }
      return s;
    }
    
    rot13("SERR YBIR?")  // "FREE LOVE?"
    
  • 相关阅读:
    JDK源码分析 – HashMap
    牛哄哄的celery
    redis数据库基础篇
    RPC的入门应用
    Python的常用模块
    消息队列之真知灼见
    面向对象编程(2)
    python3的C3算法
    面向对象编程(1)
    CRM项目之stark组件(2)
  • 原文地址:https://www.cnblogs.com/codebook/p/13190585.html
Copyright © 2011-2022 走看看