给你51单片机 CRC16计算
#include "reg51.h" 
/*******************************
冯雪松 已调试校验正确
CRC计算方法
1.预置1个16位的寄存器为十六进制FFFF(即全为1);称此寄存器为CRC寄存器;
2.把第一个8位二进制数据(既通讯信息帧的第一个字节)与16位的CRC寄存器的低
   8位相异或,把结果放于CRC寄存器;
3.把CRC寄存器的内容右移一位(朝低位)用0填补最高位,并检查右移后的移出位;
4.如果移出位为0:重复第3步(再次右移一位);
如果移出位为1:CRC寄存器与多项式A001(1010 0000 0000 0001)进行异或;
5.重复步骤3和4,直到右移8次,这样整个8位数据全部进行了处理;
6.重复步骤2到步骤5,进行通讯信息帧下一个字节的处理;
7.将该通讯信息帧所有字节按上述步骤计算完成后,得到的16位CRC寄存器的高、低
   字节进行交换;
   *///////////////////////////////////////////////////////////////////////////////////
#define uchar unsigned char 
#define uint unsigned int 
#define ufloat unsigned float 
    unsigned char a,i;
	 unsigned char  Sdata[6]={01,03,00,01,00,01}	;
     unsigned int CRC=0XFFFF;
     unsigned char CRC_count;
main()
  {	 while(1){
        
		for (a=0;a<6;a++){
		    CRC=CRC^Sdata[a];
        for(i=0;i<8;i++)
        {
            if(CRC&1)
            {
                CRC>>=1;
                CRC^=0XA001;
             }
                else CRC>>=1;
         }
 }   
        
 }
 }