华为机试–字符串ASC码+偏移量实现字符串加密的JS实现
题目描述:给出原文字符串str,通过对字符串的每个字母进行改变来实现加密,加密方式是在每一个字母str[i]偏移特定数组元素a[i]的量。数组a的前三位已经赋值:a[0]=1,a[1]=2,a[2]=4,当i>=3时,数组元素a[i]=a[i-1]+a[i-2]+a[i-3]。例如:原文abcde加密后bdgkr,其中偏移量分别是1,2,4,7,13。
输入描述:第一行是整数n,表示n组测试数据。每组数据包含一行,原文str(只含有小写字母,长度大于0小于50)。
输出描述:每组测试数据输出一行,表示密文。
//使用VScode自测通过
//n=parseInt(readline())
// for(var i=0;i<n;i++){
// var str=readline()
var str='erskaadaaz' //自测数据
var arr=[]
for(var j=0;j<str.length;j++){
var num1= str.charCodeAt(j)//获取当前字符ASC码
var num2=fn(j) //获取当前偏移量
var num3=num1+num2
if(num3>=97&&num3<=122){
arr.push(String.fromCharCode(num3))
}
else{
var num4=97+(num3-97)%26
arr.push(String.fromCharCode(num4))
}
}
console.log(arr.join(''))
// }
function fn(num){
if(num==0){
return 1
}
else if(num==1){
return 2
}
else if(num==2){
return 4
}
else{
return fn(num-1)+fn(num-2)+fn(num-3)
}
}