RC4算法示例

key为密钥~

#include < iostream >
#include
< string >
using   namespace  std;
int  s[ 256 ];
int  t[ 256 ];
string  key = " 0123456789 " ;
void  swap( int *  s1, int *  s2){
    
int  temp =* s1;
    
* s1 =* s2;
    
* s2 = temp;
}
void  init(){
    
// 初始化s和t数组
     for ( int  i = 0 ;i < 256 ;i ++ ){
        s[i]
= i;
        t[i]
= atoi( & ( const   char )(key.at(i % key.length())));
    }
    
int  j = 0 ;
    
for ( int  i = 0 ;i < 256 ;i ++ ){
        j
= (j + s[j] + t[j]) % 256 ;
        swap(s
+ i,s + j);
    }
}
void  encode( int *  start, int  length){
    
int  pos = 0 ;
    
int  i = 0 ,j = 0 ;
    
while (pos ++< length){
        i
= (i + 1 ) % 256 ;
        j
= (j + s[i]) % 256 ;
        swap(s
+ i,s + j);
        
int  temp = (s[i] + s[j]) % 256 ;
        
int  k = s[temp];
        
* start ^= k;
        start
++ ;
    }
}
void  decode( int *  start, int  length){
    encode(start,length);
}
void  print( int *  a, int  length, string  startMessage = "" ){
    cout
<< startMessage << "   " ;
    
for ( int  i = 0 ;i < length;i ++ ){
        cout
<<* (a + i) << "   " ;
    }
    cout
<< endl;
}
int  main(){
    init();
    
int  a[ 10 ] = { 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 };
    print(a,
10 , " 原数组 " );
    encode(a,
10 );
    print(a,
10 , " 加密后 " );
    init();
    decode(a,
10 );
    print(a,
10 , " 解密后 " );
}

转载于:https://www.cnblogs.com/CUCmehp/archive/2008/12/16/1356381.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值