我试着用js做一个lfsr,在它的头上,每个东西看起来都很好,我使用字符串,我来回转换它们来得到最后一位,我的问题是打印数字,我试图做一个大的十六进制数,我的逻辑是给我一个种子和一个长度,函数应该生成这个长度的十六进制数。
function lfsr(seed, length ){
var arr = Array.from(seed.toString(2));
result ="";
for (var i = 0; i < lenght; i++) {
let _last = parseInt(arr.pop());
let _blast = parseInt(arr[arr.length - 1])
let _newbit = _last ^ _blast;
arr.splice(0 , 0 ,_newbit.toString());
result += _newbit.toString();
}
return parseInt(result, 2).toString(16); 这是我的代码,我运行了一些测试,得到了很好的输出,但当我输入答案时,我得到了以下输出:
be92231350d87800000000000哦,我的输入是:
var ans = lfsr(6543123123798,100);你知道怎么去掉多余的0而得到我需要的东西吗?耽误您时间,实在对不起。
发布于 2021-09-21 11:24:08
我已将代码更改为:
function lfsr(seed, length,base){
var arr = Array.from(seed.toString(base));
var result ="";
for (var i = 0; i < length ; i++) {
let _newbit = parseInt(arr.pop(),16) ^ parseInt(arr[arr.length - 1],base);
arr.splice(0 , 0 ,_newbit.toString(base));
result += _newbit.toString(base);
}
return result;
}它解决了我的问题。欢迎任何人使用它。
https://stackoverflow.com/questions/69266160
复制相似问题