本文主要是介绍【FCC】移位密码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
要求:
移位密码也就是密码中的字母会按照指定的数量来做移位。
一个常见的案例就是ROT13密码,字母会移位13个位置。由’A’ ↔ ‘N’, ‘B’ ↔ ‘O’,以此类推。
写一个ROT13函数,实现输入加密字符串,输出解密字符串。
所有的字母都是大写,不要转化任何非字母形式的字符(例如:空格,标点符号),遇到这些特殊字符,跳过它们。
JavaScript实现
function rot13(str) { // LBH QVQ VG!var encode=[];for(i=0;i<str.length;i++){var asc = str[i].charCodeAt();if(asc<65||asc>90){encode.push(str[i]); //不在大写字母范围内的不处理}else if(asc>77){encode.push(String.fromCharCode(asc-13));//后13个字母减13}else{encode.push(String.fromCharCode(asc+13));//前13个字母加13} }encode = encode.toString().replace(/,/g,'');return encode;}
用到的资源
String.fromCharCode
String.prototype.charCodeAt
如有错误,或其他更好的建议,请在评论区指正,谢谢
这篇关于【FCC】移位密码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!