lfsr算法c语言,求助:如何用C语言实现LFSR加密

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

include

voidLFSR(unsigned char pzt[],unsigned char pjg[],int n)

{

unsigned char t=0;

int c=0,i;

for(i=0;i

t^=(pzt[i]&pjg[i]);

t^=((t<<1)^(t<<2)^(t<<3)^(t<<4)^(t<<5)^(t<<6)^(t<<7));

if (t&0x80) c=1;

for(i=n-1;i>=0;i--)

{

t=pzt[i];

pzt[i]=((t<<1)|c)&0xff;

c=(t&0x80)?1:0;

}

}

voidprint_2(int val2)

{

unsigned char *p = (unsignedchar*)&val2 + 3;

for(int k = 0; k <= 3; k++)

{

int val2 = *(p-k);

for (int i = 7; i >= 0; i--)

{

if(val2 & (1 <

printf("1");

else

printf("0");

}

printf(" ");

}

}

voidDSR(unsigned char pzt[],unsigned char pjg[],int n)

{

unsigned char t;

int c=0,i;

for(i=n-1;i>=0;i--)

{

t=pzt[i];

pzt[i]=((t<<1)|c)&0xff;

c=(t&0x80)?1:0;

}

if(c)

for(i=0;i

pzt[i]^=pjg[i];

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值