【问题标题】:trying to make an lfsr in js试图在js中制作一个lfsr
【发布时间】:2021-09-21 08:59:51
【问题描述】:

我正在尝试在 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 并获得我需要的东西吗?感谢您的宝贵时间。

【问题讨论】:

    标签: javascript lfsr


    【解决方案1】:

    我已将代码更改为:

    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; 
    }
    

    它解决了我的问题。欢迎大家使用。

    【讨论】:

      猜你喜欢
      • 2020-12-28
      • 2020-07-12
      • 1970-01-01
      • 2022-10-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多