(CRC校验的C++语言实现)

(CRC校验的C++语言实现)

#include
#include
using namespace std;
int main()
{
string str1,str2;
int arr[100],brr[100],yushu[100];
for(int i=0;i<100;i++)
{
arr[i]=0;
brr[i]=0;
yushu[i]=0;
}
while(1)
{
cout<<endl<<endl<<"----------------------------------------"<<endl;
cout<<“求校验码程序”<<endl;
cout<<“需要发送的信息码为 :”;
cin>>str1;//101100010
cout<<“生成多项式为 :”;
cin>>str2;//10001000000100001
int l1=str1.length() ;
for(int i=0;i<str1.length() ;i++)
{
arr[i]=str1[i]-‘0’;
//arr[str1.length()-i-1]=str1[i]-‘0’;
}
for(int j=0;j<str2.length() ;j++)
{
brr[j]=str2[j]-‘0’;
//brr[str2.length()-j-1]=str2[j]-‘0’;
}
for(int i=0;i<str1.length() ;i++)
{
if(arr[i]==1)
for(int j=1;j<str2.length() ;j++)
if(brr[j]==1)
if(arr[i+j]==1)
arr[i+j]=0;
else
arr[i+j]=1;
}
cout<<“码元序列为 : “;
for(int i=0;i<str1.length() ;i++)
{
cout<<str1[i];
}
for(int i=str1.length() ;i<str1.length() +str2.length()-1 ;i++)
{
cout<<arr[i];
}
cout<<‘B’<<endl;
cout<<”----------------------------------------”<<endl<<endl<<endl<<endl<<endl;
}
}
(CRC校验的C++语言实现)